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

相关文章

使用Go语言开发一个命令行文件管理工具

《使用Go语言开发一个命令行文件管理工具》这篇文章主要为大家详细介绍了如何使用Go语言开发一款命令行文件管理工具,支持批量重命名,删除,创建,移动文件,需要的小伙伴可以了解下... 目录一、工具功能一览二、核心代码解析1. 主程序结构2. 批量重命名3. 批量删除4. 创建文件/目录5. 批量移动三、如何安

python使用fastapi实现多语言国际化的操作指南

《python使用fastapi实现多语言国际化的操作指南》本文介绍了使用Python和FastAPI实现多语言国际化的操作指南,包括多语言架构技术栈、翻译管理、前端本地化、语言切换机制以及常见陷阱和... 目录多语言国际化实现指南项目多语言架构技术栈目录结构翻译工作流1. 翻译数据存储2. 翻译生成脚本

Go语言中三种容器类型的数据结构详解

《Go语言中三种容器类型的数据结构详解》在Go语言中,有三种主要的容器类型用于存储和操作集合数据:本文主要介绍三者的使用与区别,感兴趣的小伙伴可以跟随小编一起学习一下... 目录基本概念1. 数组(Array)2. 切片(Slice)3. 映射(Map)对比总结注意事项基本概念在 Go 语言中,有三种主要

C语言中自动与强制转换全解析

《C语言中自动与强制转换全解析》在编写C程序时,类型转换是确保数据正确性和一致性的关键环节,无论是隐式转换还是显式转换,都各有特点和应用场景,本文将详细探讨C语言中的类型转换机制,帮助您更好地理解并在... 目录类型转换的重要性自动类型转换(隐式转换)强制类型转换(显式转换)常见错误与注意事项总结与建议类型

Go语言利用泛型封装常见的Map操作

《Go语言利用泛型封装常见的Map操作》Go语言在1.18版本中引入了泛型,这是Go语言发展的一个重要里程碑,它极大地增强了语言的表达能力和灵活性,本文将通过泛型实现封装常见的Map操作,感... 目录什么是泛型泛型解决了什么问题Go泛型基于泛型的常见Map操作代码合集总结什么是泛型泛型是一种编程范式,允

C#多线程编程中导致死锁的常见陷阱和避免方法

《C#多线程编程中导致死锁的常见陷阱和避免方法》在C#多线程编程中,死锁(Deadlock)是一种常见的、令人头疼的错误,死锁通常发生在多个线程试图获取多个资源的锁时,导致相互等待对方释放资源,最终形... 目录引言1. 什么是死锁?死锁的典型条件:2. 导致死锁的常见原因2.1 锁的顺序问题错误示例:不同

Android kotlin语言实现删除文件的解决方案

《Androidkotlin语言实现删除文件的解决方案》:本文主要介绍Androidkotlin语言实现删除文件的解决方案,在项目开发过程中,尤其是需要跨平台协作的项目,那么删除用户指定的文件的... 目录一、前言二、适用环境三、模板内容1.权限申请2.Activity中的模板一、前言在项目开发过程中,尤

C语言小项目实战之通讯录功能

《C语言小项目实战之通讯录功能》:本文主要介绍如何设计和实现一个简单的通讯录管理系统,包括联系人信息的存储、增加、删除、查找、修改和排序等功能,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录功能介绍:添加联系人模块显示联系人模块删除联系人模块查找联系人模块修改联系人模块排序联系人模块源代码如下

PyCharm接入DeepSeek实现AI编程的操作流程

《PyCharm接入DeepSeek实现AI编程的操作流程》DeepSeek是一家专注于人工智能技术研发的公司,致力于开发高性能、低成本的AI模型,接下来,我们把DeepSeek接入到PyCharm中... 目录引言效果演示创建API key在PyCharm中下载Continue插件配置Continue引言

基于Go语言实现一个压测工具

《基于Go语言实现一个压测工具》这篇文章主要为大家详细介绍了基于Go语言实现一个简单的压测工具,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录整体架构通用数据处理模块Http请求响应数据处理Curl参数解析处理客户端模块Http客户端处理Grpc客户端处理Websocket客户端