C语言PTA练习题(编程求1+3+5+...+n,编程求n的阶乘,爬楼梯,爬楼梯(扩展),猴子吃桃,猴子吃桃(扩展),求算式前n项的和,汉诺塔游戏)

本文主要是介绍C语言PTA练习题(编程求1+3+5+...+n,编程求n的阶乘,爬楼梯,爬楼梯(扩展),猴子吃桃,猴子吃桃(扩展),求算式前n项的和,汉诺塔游戏),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

7-1 编程求1+3+5+...+n

输入一个正整数n,编程求1+3+5+...+n

要求:用递归完成。

输入格式:

输入一行,只有一个整数n (1<=n<=9999) 这里n为奇数。

输出格式:

一个正整数,表示结果。

输入样例:

在这里给出一组输入。例如:

9

输出样例:

在这里给出相应的输出。例如:

25

#include<stdio.h>
int digui(int n) {if (n == 1) {return 1;}else {return digui(n - 2) + n;}
}
int main() {int n;scanf("%d", &n);printf("%d\n", digui(n));return 0;
}

7-2 编程求n的阶乘

输入一个正整数n,编程求n的阶乘n!。n!=1*2*3*...*n

要求:用递归完成。

输入格式:

输入一行,只有一个整数n (1<=n<=20)。

输出格式:

一行,结果。

输入样例:

在这里给出一组输入。例如:

4

输出样例:

在这里给出相应的输出。例如:

24

#include<stdio.h>
long digui(int n) {if (n == 1) {return 1;}else {return digui(n-1)*n;}
}
int main() {int n;scanf("%d", &n);if(n==0){printf("1");}else{printf("%ld\n", digui(n));}return 0;
}

7-3 爬楼梯

小明爬楼梯,他可以每步可以走1级或者2级,输入楼梯的级数n,求不同的走法数。

例如:n=3,表示楼梯一共有3级,他可以每次都走一级,或者第一次走一级,第二次走两级,也可以第一次走两级,第二次走一级,一共3种方法。

要求:用递归完成。

输入格式:

输入一个正整数n,代表楼梯级数,1≤n≤30。

输出格式:

一个正整数,表示一共有多少种不同的走法。

输入样例:

在这里给出一组输入。例如:

5

输出样例:

在这里给出相应的输出。例如:

8
#include<stdio.h>
int digui(int n) {if (n == 1) {return 1;}else if (n == 2) {return 2;}else {return digui(n-1)+digui(n-2);}
}
int main() {int n;scanf("%d", &n);printf("%d\n", digui(n));return 0;
}

7-4 爬楼梯(扩展)

小明爬楼梯,他可以每步可以走1级、2级、3级,输入楼梯的级数n,求不同的走法数。

例如:n=3,表示楼梯一共有3级,他可以每次都走一级;或者第一次走一级,第二次走两级;也可以第一次走两级,第二次走一级;还可以一步走3级;一共4种方法。

要求:用递归完成。

输入格式:

输入一个正整数n,代表楼梯级数,1≤n≤30。

输出格式:

一个正整数,表示一共有多少种不同的走法。

输入样例:

在这里给出一组输入。例如:

4

输出样例:

在这里给出相应的输出。例如:

7
#include<stdio.h>
int digui(int n) {if (n == 1) {return 1;}else if (n == 2) {return 2;}else if (n == 3) {return 4;}else {return digui(n-1)+digui(n-2)+digui(n-3);}
}
int main() {int n;scanf("%d", &n);printf("%d\n", digui(n));return 0;
}

7-5 猴子吃桃

猴子吃桃子问题:猴子第一天摘下若干个桃子,当即吃了一半还不过瘾,又多吃了一个;第二天又将剩下的桃子吃掉一半又多吃了一个;以后每天早上都吃了前一天剩下的一半零一个。到了第n天想再吃时,见只剩下一个桃子,求第一天共摘了多少个桃子?

要求:用递归实现。

输入格式:

一个整数n(1≤n≤62),表示最后一天第 n 天看到还剩1个桃子。

输出格式:

一个整数,第一天共有多少个桃子

输入样例:

在这里给出一组输入。例如:

10

输出样例:

在这里给出相应的输出。例如:

1534

#include<stdio.h>
long digui(int n) {if (n == 1) {return 1;}else {return (digui(n-1)+1)*2;}
}
int main() {int n;scanf("%d", &n);printf("%ld\n", digui(n));return 0;
}

7-6 猴子吃桃(扩展)

猴子第一天摘了X个桃子,当即吃掉了一些桃子,剩下X的平方根个桃子,还不过瘾,又多吃了一个,剩下Y个;第二天又吃掉了一些,剩下Y的平方根个桃子,又多吃一个;以后每天早上都吃到剩下当前的平方根个桃子,再多吃一个。到了第n天想再吃时,见只剩下一个桃子,求第一天共摘了多少个桃子?

要求:用递归完成。

输入格式:

一个整数n(1≤n≤6),表示最后一天第 n 天看到还剩1个桃子。

输出格式:

一个整数,第一天共有多少个桃子

输入样例:

在这里给出一组输入。例如:

3

输出样例:

在这里给出相应的输出。例如:

25
#include<stdio.h>
long digui(int n) {if (n == 1) {return 1;}else {return (digui(n-1)+1)* (digui(n - 1) + 1);}
}
int main() {int n;scanf("%d", &n);printf("%ld\n", digui(n));return 0;
}

7-7 求算式前n项的和

求1+1/2+2/3+3/5+5/8+8/13+13/21……的前n项的和。

要求:用递归完成

输入格式:

第1行:一个整数n(1 <= n <= 30 )。

输出格式:

一行:一个小数,即前n项之和(保留3位小数)。

输入样例:

在这里给出一组输入。例如:

5

输出样例:

在这里给出相应的输出。例如:

3.392

#include<stdio.h>
int main()
{int i, n;double a = 1, b = 1, c, d, sum = 0;scanf("%d", &n);if (n >= 1 && n <= 30)for (i = 1; i <= n; i++){d = a / b;sum += d;c = a;a = b;b = c + a;}printf("%.3f\n", sum);return 0;
}

7-8 汉诺塔游戏

汉诺塔(Hanoi Tower)问题是印度的一个古老的传说。开天辟地的神勃拉玛在一个庙里留下了三根金刚石的棒,第一根上面套着64个圆的金片,最大的一个在底下,其余一个比一个小,依次叠上去,庙里的众僧不倦地把它们一个个地从这根棒搬到另一根棒上,规定可利用中间的一根棒作为帮助,但每次只能搬一个,而且大的不能放在小的上面。面对庞大的数字(移动圆片的次数)18446744073709551615,看来,众僧们耗尽毕生精力也不可能完成金片的移动。

汉诺塔.png

后来,这个传说就演变为汉诺塔游戏:

1.有三根杆子A,B,C。A杆上有若干碟子

2.每次移动一块碟子,小的只能叠在大的上面

3.把所有碟子从A杆全部移到C杆上

经过研究发现,汉诺塔的破解很简单,就是按照移动规则向一个方向移动金片:

如3阶汉诺塔的移动:A→C, A→B, C→B, A→C, B→A, B→C, A→C

输入格式:

一个整数N,表示A柱上有N个碟子(0<n<=10)。

输出格式:

若干行,即移动的最少步骤的每一步(从哪个柱到哪个柱)

最后一行输出最小的移动步数

输入样例:

在这里给出一组输入。例如:

3

输出样例:

在这里给出相应的输出。例如:

A To C
A To B
C To B
A To C
B To A
B To C
A To C
7
#include <stdio.h>
void move(char sour, char dest) {printf("%c To %c\n", sour, dest);
}
void towerOfHanoi(int num, char sour, char aux, char dest) {if (num == 1) {move(sour, dest);return;}towerOfHanoi(num - 1, sour, dest, aux);move(sour, dest);towerOfHanoi(num - 1, aux, sour, dest);
}int main() {int num;scanf("%d", &num);towerOfHanoi(num, 'A', 'B', 'C');printf("%lld", (1LL << num) - 1);return 0;
}

这篇关于C语言PTA练习题(编程求1+3+5+...+n,编程求n的阶乘,爬楼梯,爬楼梯(扩展),猴子吃桃,猴子吃桃(扩展),求算式前n项的和,汉诺塔游戏)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1005338

相关文章

csu 1446 Problem J Modified LCS (扩展欧几里得算法的简单应用)

这是一道扩展欧几里得算法的简单应用题,这题是在湖南多校训练赛中队友ac的一道题,在比赛之后请教了队友,然后自己把它a掉 这也是自己独自做扩展欧几里得算法的题目 题意:把题意转变下就变成了:求d1*x - d2*y = f2 - f1的解,很明显用exgcd来解 下面介绍一下exgcd的一些知识点:求ax + by = c的解 一、首先求ax + by = gcd(a,b)的解 这个

Linux 网络编程 --- 应用层

一、自定义协议和序列化反序列化 代码: 序列化反序列化实现网络版本计算器 二、HTTP协议 1、谈两个简单的预备知识 https://www.baidu.com/ --- 域名 --- 域名解析 --- IP地址 http的端口号为80端口,https的端口号为443 url为统一资源定位符。CSDNhttps://mp.csdn.net/mp_blog/creation/editor

【Python编程】Linux创建虚拟环境并配置与notebook相连接

1.创建 使用 venv 创建虚拟环境。例如,在当前目录下创建一个名为 myenv 的虚拟环境: python3 -m venv myenv 2.激活 激活虚拟环境使其成为当前终端会话的活动环境。运行: source myenv/bin/activate 3.与notebook连接 在虚拟环境中,使用 pip 安装 Jupyter 和 ipykernel: pip instal

科研绘图系列:R语言扩展物种堆积图(Extended Stacked Barplot)

介绍 R语言的扩展物种堆积图是一种数据可视化工具,它不仅展示了物种的堆积结果,还整合了不同样本分组之间的差异性分析结果。这种图形表示方法能够直观地比较不同物种在各个分组中的显著性差异,为研究者提供了一种有效的数据解读方式。 加载R包 knitr::opts_chunk$set(warning = F, message = F)library(tidyverse)library(phyl

uva 10061 How many zero's and how many digits ?(不同进制阶乘末尾几个0)+poj 1401

题意是求在base进制下的 n!的结果有几位数,末尾有几个0。 想起刚开始的时候做的一道10进制下的n阶乘末尾有几个零,以及之前有做过的一道n阶乘的位数。 当时都是在10进制下的。 10进制下的做法是: 1. n阶位数:直接 lg(n!)就是得数的位数。 2. n阶末尾0的个数:由于2 * 5 将会在得数中以0的形式存在,所以计算2或者计算5,由于因子中出现5必然出现2,所以直接一

透彻!驯服大型语言模型(LLMs)的五种方法,及具体方法选择思路

引言 随着时间的发展,大型语言模型不再停留在演示阶段而是逐步面向生产系统的应用,随着人们期望的不断增加,目标也发生了巨大的变化。在短短的几个月的时间里,人们对大模型的认识已经从对其zero-shot能力感到惊讶,转变为考虑改进模型质量、提高模型可用性。 「大语言模型(LLMs)其实就是利用高容量的模型架构(例如Transformer)对海量的、多种多样的数据分布进行建模得到,它包含了大量的先验

PTA求一批整数中出现最多的个位数字

作者 徐镜春 单位 浙江大学 给定一批整数,分析每个整数的每一位数字,求出现次数最多的个位数字。例如给定3个整数1234、2345、3456,其中出现最多次数的数字是3和4,均出现了3次。 输入格式: 输入在第1行中给出正整数N(≤1000),在第二行中给出N个不超过整型范围的非负整数,数字间以空格分隔。 输出格式: 在一行中按格式“M: n1 n2 ...”输出,其中M是最大次数,n

dp算法练习题【8】

不同二叉搜索树 96. 不同的二叉搜索树 给你一个整数 n ,求恰由 n 个节点组成且节点值从 1 到 n 互不相同的 二叉搜索树 有多少种?返回满足题意的二叉搜索树的种数。 示例 1: 输入:n = 3输出:5 示例 2: 输入:n = 1输出:1 class Solution {public int numTrees(int n) {int[] dp = new int

国产游戏崛起:技术革新与文化自信的双重推动

近年来,国产游戏行业发展迅猛,技术水平和作品质量均得到了显著提升。特别是以《黑神话:悟空》为代表的一系列优秀作品,成功打破了过去中国游戏市场以手游和网游为主的局限,向全球玩家展示了中国在单机游戏领域的实力与潜力。随着中国开发者在画面渲染、物理引擎、AI 技术和服务器架构等方面取得了显著进展,国产游戏正逐步赢得国际市场的认可。然而,面对全球游戏行业的激烈竞争,国产游戏技术依然面临诸多挑战,未来的

Spring框架5 - 容器的扩展功能 (ApplicationContext)

private static ApplicationContext applicationContext;static {applicationContext = new ClassPathXmlApplicationContext("bean.xml");} BeanFactory的功能扩展类ApplicationContext进行深度的分析。ApplicationConext与 BeanF