- 1、本文档共62页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
PAGE
目录
TOC\o1-3\h\z\uCS81:菲波那契数列 1
CS82:二叉树 2
CS83:逆波兰表达式 4
CS84:放苹果 5
CS85:红与黑 7
CS86:八皇后问题 9
CS87:木棍问题 14
CS88:城堡 17
CS89:分解因数 19
CS810:迷宫 21
CS811:算24(未做) 23
CS812:文件结构“图”(未做) 24
CS813:小游戏(未做) 26
CS814:碎纸机(未做) 27
CS815:棋盘分割(未做) 29
CS816:棋盘问题(未做) 30
CS317: 31
CS318: 33
CS319: 34
CS320: 38
CS321: 41
CS322: 45
CS323: 46
CS324: 48
CS325: 50
CS326: 52
CS327: 54
CS328: 57
CS329: 59
PAGE1
《算法与程序实践》习题解答8——递归
让我们来看看计算n的阶乘的计算机程序的写法,很直接地我们会用一个循环语句将n以下的数都乘起来:
intn,m=1;
for(inti=2;i=n;i++)m*=i;
printf(“%d的阶乘是%d\n”,n,m);
因为n的阶乘定义为n乘以n-1的阶乘,所以还可以用下面的方法来求n的阶乘:
intfactorial(intn){
if(n=0)return(-1);
if(n==1)return1;
elsereturnn*factorial(n-1);
}
上面这两种实现方式体现了两种不同的解决问题的思想方法。第一种通过一个循环语句来计算阶乘,其前提是了解阶乘的计算过程,并用语句把这个计算过程模拟出来。第二种解决问题的思想是不直接找到计算n的阶乘的方法,而是试图找到n的阶乘和n-1的阶乘的递推关系,通过这种递推关系把原来问题缩小成一个更小规模的同类问题,并延续这一缩小规模的过程,直到在某一规模上,问题的解是已知的。这样一种解决问题的思想我们称为递归的思想。
递归方法的总体思想是将待求解问题的解看作输入变量x的函数f(x),通过寻找函数g,使得f(x)=g(f(x-1)),并且已知f(0)的值,就可以通过f(0)和g求出f(x)的值。这样一个思想也可以推广到多个输入变量x,y,z等,x-1也可以推广到x-x1,只要递归朝着出口的方向走就可以了。
CS81:菲波那契数列
(来源:poj.grids.cn2753,程序设计导引及在线实践(李文新)例9.2P198)
问题描述:
菲波那契数列是指这样的数列:数列的第一个和第二个数都为1,接下来每个数都等于前面2个数之和。
给出一个正整数a,要求菲波那契数列中第a个数是多少。
输入:
第1行是测试数据的组数n,后面跟着n行输入。每组测试数据占1行,包括一个正整数a(1=a=20)。
输出:
输出有n行,每行输出对应一个输入。输出应是一个正整数,为菲波那契数列中第a个数的大小。
样例输入:
4
5
2
19
1
样例输出:
5
1
4181
1
解题思路:
这个题目要求很明确,因为a的规模很小,所以递归调用不会产生栈溢出的问题。设第n项值为f(n),则f(n)=f(n-1)+f(n-2)。已知f(1)=1,f(2)=1,则从第3项开始,可以用公式求。
参考程序:
#includestdio.h
intf(inta)
{
if(a==1||a==2)return1;
returnf(a-1)+f(a-2);
}
intmain()
{
intn;
inti;
scanf(%d,n);
for(i=1;i=n;i++)
{
inta;
scanf(%d,a);
printf(%d\n,f(a));
}
return0;
}
CS82:二叉树
(来源:poj.grids.cn2756,程序设计导引及在线实践(李文新)例9.3P199)
问题描述:
图8-1满二叉树
如图8-1所示,由正整数1,2,3,...组成了一棵无限大的二叉树。从某一个结点到根结点(编号是1的结点)都有一条唯一的路径,比如从10到根结点的路径是(10,5,2,1),从4到根结点的路径是(4,2,1),从根结点1到根结点的路径上只包含一个结点1,因此路径就是(1)。对于两个结点x和y,假设他们到根结点的路径分
您可能关注的文档
- 《算法与程序实践2》习题解答-查找.docx
- 《算法与程序实践2》习题解答-动态规划.docx
- 《算法与程序实践2》习题解答-排序.docx
- 《算法与程序实践2》习题解答-搜索算法.docx
- 《算法与程序实践2》习题解答-贪心算法.docx
- 2022-2023学年福建省厦门市第一中学物理九上期末调研模拟试题含解析.pdf
- 2021年除夕的小学作文锦集8篇 .pdf
- 2021年湘教版九年级化学上册月考月考试卷及答案【学生专用】.pdf
- 2021部编人教版二年级上册语文教学工作计划及教学进度安排 .pdf
- 2020-2021中考数学 二元一次方程组易错压轴解答题专题练习(含答案.pdf
- +第13课亚非拉民族独立运动导学案 高中历史统编版(2019)必修中外历史.pdf
- 2022-2023学年山东省枣庄市滕州市荆河街道滕南中学七年级(上)期末语文.pdf
- 2021护士年终工作总结5篇 .pdf
- 2017新人教版部编二年级上册语文教学工作计划 .pdf
- 2007-2008-2Java语言程序设计期中11考试试题 .pdf
- 2021-2022学年三年级上学期数学期末试卷A卷 .pdf
- 2021年福建省漳州市漳浦第一中学高一地理模拟试题含解析 .pdf
- 2020年资格考试《中级法律法规与综合能力》考前练习(第41套).pdf
- 2021年优质课《莫高窟》教学设计与反思 .pdf
- 2021-2022学年湖南省娄底市新化县九年级(上)期末化学试卷(附详解).pdf
最近下载
- 五四制初中一年级中华优秀传统文化教学设计.pptx VIP
- 《微生物与健康》课件科学六年级上册.pptx
- 七年级上册生物学《生物体的结构层次》单元作业设计.docx
- 电子信息工程职业规划 (第二版).pptx VIP
- 党的二十届三中全会精神测试题300道(单选、多选、判断、填空).docx VIP
- 部编教材年级识字课教学.ppt VIP
- 贵州省贵阳市2024-2025学年高一上学期10月联合考试(一) 数学 PDF版含解析.pdf
- 基于Android的个人生活行为记录及习惯养成平台的设计与实现-毕业设计.doc
- 中国传媒大学-节目主持艺术基础(第二版)-课件.pptx
- 纤维增强复合材料在建筑工程结构加固中的应用(经济论文资料).doc
网络工程师持证人
本人已从事浙江省工程咨询5年,对浙江省内工程信息非常熟悉,可获取新建工程相关联系人、设计院、业主等关键信息。另外从事楼宇自控专业已10年,考取了一建二建等资格证书,有关考试方面的问题(考试心得、方法、学习资料等)都欢饮来咨询交流。
文档评论(0)