- 1、本文档共50页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 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;
您可能关注的文档
- 软件工程与项目管理基础知识.docx
- 第二章 NBU更换磁带机操作步骤.doc
- 如何禁止U盘拷贝文件.docx
- 怎样修改合同.ppt
- 主板维修之主板时钟电路检修教程要领.doc
- 统计学第二套作业指南.docx
- 党课复习题与答案.doc
- 专用工具清单课件.doc
- 第四章 服务 ―― 集合.pdf
- 雅思图表类小作文必备模板(附件).pdf
- 新的一年工作展望.docx
- 医生年终个人工作的述职报告(3篇).docx
- 2023年消防设施操作员之消防设备中级技能考前冲刺练习题附答案详解.docx
- 2022-2023年环境影响评价工程师之环评技术导则与标准通关练习题包括详细解答.docx
- 2023年中级注册安全工程师之安全生产管理考前冲刺检测卷和答案.docx
- 2023年中级银行从业资格之中级银行管理考前冲刺测试卷提供答案解析.docx
- 2023年公共营养师之二级营养师通关模拟考试试卷附带答案.docx
- 证券分析师之发布证券研究报告业务考前冲刺模拟题库.docx
- 2022-2023年二级建造师之二建建设工程法规及相关知识综合提升测试卷附答案.docx
- 2023年二级建造师之二建机电工程实务通关模拟考试试卷提供答案解析.docx
文档评论(0)