- 1、本文档共12页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第7章 程序设计基本方法.ppt
递归举例 折半查找法 随机数问题 * 第7章 程序设计基本算法 例:我国古代数学家在《算经》中出了一道题:“鸡翁一,值钱五;鸡母一,值钱三;鸡雏三,值钱一。百钱买百鸡,问鸡翁母雏各几何?”意为:公鸡每只5元,母鸡每只3元,小鸡3只1元。用100元买100鸡,问公鸡、母鸡、小鸡各多少只? §7.1 穷举算法 for(i=0;i=100;i++) { for(j=0;j=100;j++) k=100-i-j; if (5*i+3*j+k/3==100) printf(“%d,%d,%d”,i,j,k) } 7.2 迭代与递推算法 #include stdio.h void main() { long sum=0, f=1; int n; for (n=1; n=10; n++) { f=f*n; sum+=f; } printf(“Result: %ld”, sum); } 迭代:用一个变量既描述新状态又描述旧状态,变量的新值是在其旧值的基础上推出的。 递推:新状态用新的变量描述,而新变量的值是在旧变量的值的基础上推出来的。 例 用数组求Fibonacci数列前20个数 f[0] f[1] f[2] f[3] f[4] f[5] f[19] ……... 1 1 f[19] 0 1 4 5 2 3 19 2 3 5 递推: #include stdio.h main() { int i; long int f[20]={1,1}; for(i=2;i20;i++) f[i]=f[i-2]+f[i-1]; for(i=0;i20;i++) { if(i%5==0) printf(\n); printf(%l2d,f[i]); } } 斐波那契数列 不用数组:(迭代) #includestdio.h main() {long int f1=1;f2=1; printf(“%ld,%ld”,f1,f2); for(i=2;i=10;i++) {f1=f1+f2; f2=f2+f1; printf(“%ld,%ld”,f1,f2); } } 7.3 递归调用 定义:在调用一个函数的过程中又出现直接或间接的调用该函数本身,称函数的递归调用。C语言的特点之一,就在于允许函数递归调用 age(5)=age(4)+2 age(4)=age(3)+2 age(3)=age(2)+2 age(2)=age(1)+2 age(1)=10 例: 用通式表示:age(n)=10 (n=1) age(n)=age(n-1)+2 (n1) 说明 C编译系统对递归函数的自调用次数没有限制 每调用函数一次,在内存堆栈区分配空间,用于存放函数变量、返回值等信息,所以递归次数过多,可能引起堆栈溢出 #includestdio.h main() {printf(“%d”,age(5)); } age(int n) {int c; if(n==1) c=10; else c=age(n-1)+2 return c; } age(n)=10 (n=1) age(n)=age(n-1)+2 (n1) 例 求n的阶乘 #include stdio.h int fac(int n) { int f; if(n0) printf(n0,data error!); else if(n==0||n==1) f=1; else f=fac(n-1)*n; return(f); } main() { int n, y; printf(Input a integer number:); scanf(%d,n); y=fac(n); printf(%d! =%15d,n,y); } #includestdio.h void fun() { char c; c=getchar(); if(c==#) printf(%c,c); else { fun(); printf(%c,c); // printf(kdjfkdj\n);
您可能关注的文档
- 用例编写方法及管理流程说明.doc
- 用无线路由器 实现通宵BT下载.doc
- 用旭日图展示数据的三种方法.pdf
- 电容细胞计数.pdf
- 病句与重排.doc
- 种植基地管理制度未修改.doc
- 空间层次聚类显著性判别的重排检验方法_唐建波.pdf
- 第1课网上邮局--在Web上收发电子邮件.doc
- 第2 章 非食源性物质 - 副本.doc
- 第8章 自定义对象.pdf
- 化学反应速率与平衡.ppt
- 企业会计信息质量问题及对策【精品发布】.doc
- 免疫学的应用高二上学期生物人教版选择性必修一.pptx
- 高中物理自由落体运动课题研究力学部分+课件+-2023-2024学年高一上学期物理人教版必修第一册.pptx
- 北师大版生物七年级上册 《细胞的基本结构和功能》第2课时CEP课件1.pptx
- Unit 4 Grammar and usage(教学课件)-高中英语牛津译林版(2020)选择性必修第三册.pptx
- 特异性免疫高二上学期生物人教版选择性必修1.pptx
- 期末复习课件专题9+物体的浮沉条件及应用(2)++2023-2024学年人教版八年级物理下册.pptx
- 其他植物激素高二上学期生物人教版选择性必修1.pptx
- 三大费用核算节税技巧【会计实务操作教程】.pptx
最近下载
- 2022-2023学年四川省成都市金牛区七年级(下)期末英语试卷(附答案详解).pdf VIP
- 重点难点关键部位施工及处理措施.docx
- 金属钠的性质说课稿课件.pptx VIP
- 2021级专业人才培养方案(区块链技术应用专业)(高职).pdf
- 2024首届全国红旗杯班组长大赛题库及答案(2001-4000题).docx VIP
- 2024首届全国红旗杯班组长大赛题库及答案 (1一2000题).docx VIP
- c1跨学科学习学生成果及点评小学韵.docx VIP
- GB∕T 40170-2021 质粒抽提及检测通则.pdf
- 数控专业毕业论文-端盖类零件的建模与仿真加工.doc
- 2024年浙江省宁波市江北区中考一模科学试卷+答案解析.pdf VIP
文档评论(0)