第7章 程序设计基本方法.pptVIP

  1. 1、本文档共12页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 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);

文档评论(0)

zhoujiahao + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档