C语言 第七讲.函数.ppt

  1. 1、本文档共50页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
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;

文档评论(0)

0520 + 关注
实名认证
内容提供者

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

1亿VIP精品文档

相关文档