- 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
- DB23_T 3866-2024冰上龙舟赛事组织服务规范.docx
- DB32 2163-2012 棉纱单位可比综合电耗限额及计算方法.docx
- DB32∕T 2429-2013 棉花田间生长发育观察记载规范.docx
- DB23_T 3820-2024 工业互联网综合平台数据质量管理规范.docx
- DB23_T 3474-2023非煤智慧矿山信息系统技术规范.docx
- DB3201_T 1106-2022 工程地质层划分技术规范.docx
- DB33T 2515-2022公共机构“零碳”管理与评价规范.docx
- DB3301_T 0415-2023 装修垃圾收运处置管理规范.docx
- DB3311/T 106―2019“丽水山居”民宿服务要求与评价规范.docx
- DB3201T 1127-2022 慈善捐赠受赠管理规范.docx
最近下载
- 亿赛通电子文档安全管理系统V5.0--客户端使用手册V1113379.pdf VIP
- [标准规范]煤矿窄轨铁道维修质量标准及检查评级办法(精编).doc VIP
- 人教统编版小升初语文总复习专题七:句式变换课件(共28张PPT).ppt VIP
- 2025重庆永川区板桥镇村(社区) 后备干部选拔笔试备考试题及答案解析.docx VIP
- 深度解析《GBT 44026-2024预制舱式锂离子电池储能系统技术规范》.pptx
- 品质部各岗位职责说明书.pdf VIP
- 2022.01 深圳南山红花岭工业区城市更新项目一期建筑方案设计 华艺.pdf VIP
- 电冰箱安全技术规程培训.pptx VIP
- 07FK02 防空地下室 通风设备安装.pdf VIP
- 解决我国农民负担问题的路线图设想-中国发展.pdf
文档评论(0)