模块化程序设计讲解.pptVIP

  1. 1、本文档共69页,可阅读全部内容。
  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文档。上传文档
查看更多
3.2 函数的定义 函数分类 从用户角度 标准函数(库函数):由系统提供 用户自定义函数 从函数形式 无参函数 有参函数 参数传递方式 值传递方式 方式:函数调用时,为形参分配单元,并将实参的值复制到形参中;调用结束,形参单元被释放,实参单元仍保留并维持原值 特点: 形参与实参占用不同的内存单元 单向传递,实参的值传给形参 3.7 变量的作用域与存储类型 3.7.1变量的作用域 所谓变量的作用域是指该变量有效的区域。按照变量的作用域,将C语言的变量分为局部变量和全局变量。 一、局部变量---内部变量 位于一对花括号之间的所有语句称为一个代码块(也称为复合语句)。 定义:出现在代码块开始位置的变量。 说明: 局部变量的作用域仅限于定义它的代码块内 main中定义的变量只在main中有效 不同函数中同名变量,占不同内存单元 形参属于局部变量 可定义在复合语句中,且只在该复合语句中有效的变量 定义:任何在所有代码块之外定义的变量。 有效范围:从定义变量的位置开始到本源文件结束 例3.19 求三个数中的最大值和平均值用函数实现: 用递归的方法求n! 非法 n0 1 n=0,1 n*(n-1)! n0 n!= 递归的终止条件 递归方式 4!=4*(4-1)! 返回值6 返回值2 返回值1 3!=3*(3-1)! 2!=2*(2-1)! 1!=1 主调函数 返回值24 调用 例3.11_2 求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); } main函数 输入m ③ y=fac(m) 输出y ⑥ 调用fac m?n ③ 因 3!=0,1 f=3*fac(3-1) 返回f ⑥ 调用fac m?n ② 返回f ② 返回f ① 因 2!=0,1 f=2*fac(2-1) 调用fac m?n ① 因1==1 f=1 结束 递归调用过程: main() fac(3) fac(2) fac(1) fac(3)*4 fac(2)*3 fac(1)*2 6 2 1 结果:24 3.6 库函数的使用(自学) 使用库函数应注意: 1、函数功能 2、函数参数的数目和顺序,及各参数意义和类型 3、函数返回值意义和类型 4、需要使用的包含文件 见教材例附录A 上节回顾 1、函数嵌套调用: main( ) 调用函数a 结束 a函数 b函数 调用函数b ? ? ? ? ? ? ? ? ? 函数b( ) { } 函数a( ) { 函数b; } main() { 函数a; } #include stdio.h int fac(int n) { int f; if(n1) f=-1; else if(n==1||n==2) f=1; else f=fac(n-2)+fac(n-1); return(f); } void main() { int n, y; printf(Input a integer number:); scanf(%d,n); y=fac(n); if(y==-1) printf(“Input error!\n”); else printf(“%15d,y); } 2、函数递归调用: int fac(int n) { int f,f1=1,f2=1,i; if(n1) f=-1; else if(n==1||n==2) f=1; else for(i=3;i=n;i++)

文档评论(0)

挑战不可能 + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档