- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
C语言 第七章.函数
C语言程序设计 函数 1、不同函数中可以使用相同名字的变量; 2、形参也是局部变量; 3、复合语句中定义的变量只在本复合语句内有效。 #includestdio.h void test_auto() { int v=0; printf(v=%d\n,v); v++; } void main() { int i; for(i=0;i4;i++) test_auto(); } 使程序控制从被调用函数返回到主调函数中,同时把表达式值(返回值)带给主调函数。 递归:递推、回归 递归的特别之处在于递归分解的子问题与原问题具有相同性质和相同的表现形式,但子问题比原问题规模小了,变得简单了。 采用递归方法处理问题的关键:1.找出求解的递归公式;2.确定递归结束条件。 a、形参只有当调用时才临时分配存储单元(局部变量)。 b、实参一定要有确定的值,可以是表达式 c、实参和形参的类型应相同或赋值相容。 传址实际是传值方式的一个特例,本质还是传值,只是此时传递的是一个地址数据值。 #include stdio.h void find(/**/ int m /**/) { int a1,a2; a1=m%10; a2=m/10; if(m%3==0 (/**/ a1==4 || a2==4 /**/)) printf(%d\n,m); } void main() { int k; for(k=10;k=99;k++) /**/ find( k ) /**/; getch(); } double fun(double x,int n) { int i; double f=0.0,s,fz=2,fm=3; for(i=1;i=n;i++) { if(i%2==0)s=x*fz/fm; else s=fz/fm/x; f+=s; fm=fz+fm; fz=fm-fz-fz; } return f; } main() { printf(fun(6.66,8)=%8.3f\n,fun(6.66,8)); printf(fun(6.66,15)=%8.3f\n,fun(6.66,15)); } #includestdio.h #includemath.h int prime(int x) { int i, mark=1; double k; /**/ i=1 /**/; k=(int)sqrt((double)x); while (i=k) { if(x%i==0){/**/i=k+1;/**/break;} i++; } return (mark); } void main() { int a; printf(Input a number: ); scanf(%d,a); if(/**/!prime(a)/**/) printf(%d is a prime number.\n,a); else printf(Its not.\n); getch(); } #includemath.h double fun(double x) { double y=0.0; if(x2)y=x*x+1.34*x-1.21; else if(x==2)y=log(x)+3*x; else y=cos(x); return y; } main() { printf(fun(0.76)=%8.3f\n,fun(0.76)); printf(fun(2.0)=%8.3f\n,fun(2.0)); printf(fun(2.76)=%8.3f\n,fun(2.76)); } 例:以下程序的运行结果是? #include stdio.h int fun(int n) { if(n==1) return 1; else return n*fun(n-1); } void main() { int z; z=fun(3); printf(%d\n,z); } A.1 B.2 C.3 D.6 例:以下程序的功能是用递归算法求1!+3!+5!+7!+9! #include stdio.h long int fsum(int n) { long int k; if(n==1) /**/ k=0 /**/; else k=n*fsum(n-1); return (/**/ 1 /**/); } void main() { int i; long int sum;
您可能关注的文档
- 《北京理工大学学报》(自然科学中文版)稿件版式要求.doc
- 【猫の儿-贡献】高考英语词组正反超强背诵.doc
- 【聚焦中考】(浙江地区专版)2014中考英语总复习 第3讲 七上 Modules 8-10考点跟踪突破.doc
- 【精品】(山西省专用)2011届高三英语二轮复习 考前特训必读第1天应知必会专题课件.ppt
- 【金版学案】2014高考英语总复习(语法填空+阅读理解+写作训练)基础知识 每日一练1 北师大版.doc
- 七年级英语期末试题.1doc.doc
- 上海市市西中学10-11学年高二上学期期中考试(英语).doc
- 上海市长宁区2014届高三英语上学期期末考试试题(上海长宁一模)牛津上海版.doc
- 三、外语学院硕士学位论文模板.doc
- 一种CAST基因过表达小鼠的建立.doc
文档评论(0)