第7章语言.pptVIP

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

第七章 函数;;7.1 模块化程序设计与函数;基本概念;模块与函数;模块与函数;模块与函数;例:分数排序; void main() {float a,b,c; scanf(%f%f%f, a,b,c);/* 输入 */ sortabc(a,b,c); /* 排序 */ putabc(a,b,c); /* 输出a,b,c三个数 */ } ;void sortabc(float *a,float *b,float *c ) { float t; if (*a *b) {t=*a; *a=*b; *b=t;} /* 交换a和b 的值 */ if (*b *c) {t=*b; *b=*c; *c=t;} /* 交换b和c 的值 */ if (*a *b) {t=*a; *a=*b; *b=t;} /* 交换a和b 的值 */ };char grade(float x) /*根据x的值,得到等级标准*/ {if (x=85) return(A); else if (x=70) return(B); else if (x=60) return (C); else return (D); }; void putabc(float a,float b,float c) {char g; g = grade(a); /*判别等级 */ printf(%6.1f :%c,a,g); g = grade(b); printf(%6.1f:%c,b,g ); g = grade(c); printf(%6.1f:%c,c,g); } ;模块设计的原则; 独立性原则表现在模块完成独立的功能,和其它模块间的关系简单,各模块可以单独调试。修改某一模块,不会造成整个程序的混乱。; 模块之间最好只通过数据传递发生联系,而不发生控制联系。 例如,C语言禁止goto语句作用到另一个函数, 就是为了保证函数的独立性。; 模块内使用的数据,对于不需要这些数据的其它模块来说,应该不允许使用;在一个模块内的变量的修改不会影响其它模块的数据。即模块的私有数据只属于这个模块。C语言的局部变量,就是满足模块独立的的需要。; 模块不能太大,但也不能太小。模块的功能复杂,可读性就不好,而且也违背独立性原则。但如果做得太小,实际上也会复杂各个模块间反复调用,可读性也会降低。这点需要慢慢积累经验,好好把握。;7.2 函数的定义与调用; C语言程序处理过程全部都是以函数形式出现,最简单的程序至少也有一个main函数。函数必须先定义和声明后才能调用。 ;标准库函数;自定义函数;函数的主要知识点;函数举例 例7.1 求两个数的最大值。;;自定义函数的声明;求1!+2!+3!+…+10!;求1!+2!+3!+…+10! 程序;定义求 n! 的函数;形参与实参的关系;实参与形参;函数返回值;return 的数据类型与函数的类型矛盾时,自动将数据转换成函数的类型。;函数没有返回值时, 函数应定义成空类型。;7.3 函数的嵌套调用和递归调用;[例7.5] 计算s=1k+2k+3k+……+N k /*功能:函数的嵌套调用*/ #define K 4 #define N 5 long f1(int n,int k) /*计算n的k次方*/ { long power=1; int i; for(i=1;i=k;i++) power *= n; return power; };long f2(int n,int k) /*计算1到n的k次方之累加和*/ { long sum=0; int i; for(i=1;i=n;i++) sum += f1(i, k); return sum; } main() { printf(Sum of %d powers of integers from 1 to %d = ,K,N); printf(%d\n,f2(N,K)); getch(); } ;嵌套调用求组合数; 函数调用它本身,称为递归。直接在函数内调用自己为直接递归

文档评论(0)

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

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

1亿VIP精品文档

相关文档