程序设计基础第5章(2010级)[精选].pptVIP

  1. 1、本文档共83页,可阅读全部内容。
  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文档。上传文档
查看更多
程序设计基础第5章(2010级)[精选]

重 点: 函数的定义、函数的调用与参数传递 、递归算法、指针与函数、变量的存储类型与作用域 难 点: 参数传递 、递归算法、指针与函数、变量的作用域 5.1结构化程序设计的基本思想和方法 问题 所要解决的问题的规模越来越大,复杂性越来越高。例如学生成绩管理就不是一个算法可以解决的。 成绩管理至少会涉及到: ①成绩的输入并长期保存 ②成绩的输出并展示给用户 ③成绩单的修改 ④成绩的查询 ⑤成绩的处理 解决的基本思想——分而治之 将问题拆分成几个规模较小、相对独立的几个部分(称为模块),如果某个或几个部分仍然规模较大、复杂,可继续将这些部分分成更细的若干小部分。这一过程称为逐步细化。直至分解到很容易处理这些小问题。 结构化程序设计分解模块的方法 “自顶向下、逐步细化”,即从功能的角度,把抽象的问题,逐步分解变成具体的一个一个功能(即模块)。 顶层是抽象的问题,按层次结构向下分解成相对具体的功能,如果分解后的功能仍很抽象,规模较大,可继续按层次向下分解成更为具体的小的功能。 基本形式 模块设计的原则 5.2函数及其定义 5.2.1模块与函数 C/C++语言用函数来实现程序模块 程序整体由一个或多个函数的程序块组成。 main函数是整个程序执行时的入口和结束时的出口。 每个函数都具有各自独立的功能 C/C++语言支持模块化程序的方法:函数和包含文件 函数返回值所具有的数据类型与变量类型相同。 (1)返回值是数值 可以是带符号或unsigned的char、int、short、long型以及float、double型等 (2)返回值是地址 类型是指针型 (3)函数没有返回值 类型是void (4)返回语句:return(表达式)、return 表达式、 return 形式参数 函数可以带有零个或多个形式参数。 形参是是主调函数和被调函数之间的接口。 形参是函数的内部变量。即形式参数仅限于在函数内部使用。 形式参数只是形式化的内部变量,即只有当函数被调用时,形式参数才被建立,用来接受调用函数传递来的实际参数,函数执行完之后,形式参数将被撤消不再存在。 函数定义的位置 函数不能嵌套定义,即函数的定义不能在函数体内。 函数定义的具体位置没有严格的限定,可以与主调函数在同一个源程序文件中,也可以不在同一个源程序文件中。可以在主调函数之前,也可以在主调函数之后。 5.2.4函数的声明 如果定义的函数在主调函数之后,或不与主调函数不在同一个源程序文件中,在主调函数中使用所定义之前必须对其进行声明。声明的形式为: 类型符 函数名(形参列表); 即重写一遍函数头。 #include conio.h void main() { int a,b,m; ???????????? ? /*说明变量*/ ? int max(int a,int b);?? /*函数声明*/ ? scanf(%d,%d,a,b);?? /*调用库函数scanf*/ ? m=max(a,b); ?????????? ?? *调用字定义函数max*/ ? printf(max=%d\n,m));? /*调用库函数printf*/ ? getch(); ????????????? ? /*调用库函数getch*/ } int max (int a,int b)????? /*定义函数max*/ { ? int y; ? y=(ab)? a:b; /*条件表达式 */ return y; } 例5.2求1!+2!+3!+…+10! 程序 void main() { long mm( int ); /*自定义求阶乘函数应先声明 */ int i; long s=0; for (i =1; i =10; i ++) s+= mm(i ); /*调用求阶乘函数,求I的阶乘 */ printf(“\n%ld”,s); } 定义求 n! 的函数 long mm( int n) { long t=1; int i; for (i =1; i =n; i ++) t *= i ; return t ; } 例5.3编写一个求x的n次方的函数. #includestdio.h double power(double x,int n) //定义函数 { double value=1.0; while(n--) value*=x; return value; }

您可能关注的文档

文档评论(0)

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

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

1亿VIP精品文档

相关文档