- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 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();
}
;嵌套调用求组合数; 函数调用它本身,称为递归。直接在函数内调用自己为直接递归
您可能关注的文档
最近下载
- 员工心态培训ppt课件.pptx VIP
- 直肠癌的外科治疗及进展.ppt VIP
- 2025年上海证券交易所招聘笔试预测试题及答案.doc VIP
- 料账管理课件.pptx VIP
- 能量密度指数(EII)计算方法.ppt VIP
- 红十字校本课程教学设计.docx VIP
- (正式版)Y-S-T 1700-2024 银矿采选业绿色工厂评价要求.docx VIP
- 2025年上海证券交易所招聘笔试专项练习含答案.doc VIP
- TCECA-G 0344—2025《零碳园区评价技术规范》.pdf VIP
- 第2课 春秋战国的历史巨变课件(共41张PPT)-中职高一上学期高教版(2025)中国历史全一册(含音频+视频).pptx VIP
文档评论(0)