




已阅读5页,还剩6页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
本章重点 11.1 传给main函数的参数 11.2 通过实参向函数传递函数名或指向函数的指针变量 11.3 函数的递归调用 11.4 函数的嵌套调用,第11章 对函数的进一步讨论,11.1 传给main函数的参数 1.1.1 算法的基本概念 在第7章我们学习了函数的定义和调用,以及函数之间不同类型数据的传递。在此之前,我们在编写main函数时,其后的括号中没有参数。但在运行C程序时,可以通过运行C程序的命令行,把参数传给C程序。main函数通常可用两个参数 例如: main(int argc, char *argv),其中,argc和argv是两个参数名,可由用户自己命名,但它们的类型是固定的。第一个参数argc必须是整型,第二个参数argv是一个指向字符型的指针数组的指针,这个字符型指针数组的每个指针都指向一个字符串。 11.2 通过实参向函数传递函数名或指向函数的指针变量 1指向函数的指针变量的定义,C语言中,函数名代表该函数的入口地址,因此,可以定义一种指向函数的指针存取这个地址。指向函数的指针变量的一般定义形式为: 数据类型标识符 (*指针变量名)(); 例如: int (*p)(); 表示定义一个指向函数的指针变量,但指向的函数值必须是int。 说明: (1)函数的调用可以通过函数名调用,也可以通过函数指针调用(即用指向函数的指针变量调用)。,(2)(*p)()表示定义一个指向函数的指针变量,这不是固定指向哪一个函数,而只是表示定义了这样一个类型的变量,它是专门用来存放函数的入口地址的。在程序中把哪一个函数的地址赋给它,它就指向哪一个函数。在一个程序中,一个指针变量可以先后指向不同的函数。 (3)在给函数指针变量赋值时,只需给出函数名而不必给出参数。 例如:定义了一个函数 int max(int x,int y); 希望指针p指向它的入口地址,其形式是: p=max;,(4)用函数指针变量调用函数时,只需将(*p)代替函数名即可,在(*p)之后的括号中根据需要写上实参。例如上例中,要调用max(a,b),可以写成: c=(*p)(a,b); (5)对指向函数的指针变量,像p+n、p+、p等运算是无意义的。 函数名或指向函数的指针变量可以作为实参传给函数。这时,对应的形参应当是类型相同的指针变量。例如: double tran(double (*)(double), double (*)(double), double );,11.3 函数的递归调用 C语言中允许函数的递归调用,所谓函数的递归是指在调用一个函数的过程中,又出现了直接或间接地调用该函数本身。在此仅讨论直接递归,即函数自身调用自身。,1递归问题的特征 为求解规模为n的问题,设法将它分解成规模较小的问题,然后从这些小问题的解方便地构造出大问题的解,并且这些规模较小的问题也能采用同样的分解和综合方法,分解成规模更小的问题,并从这些更小问题的解构造出规模较大问题的解。特别是当规模n=1时,能直接得解。,2递归函数的执行过程 为了理解递归的含义,可通过一个简单的例子来加以说明。例如,求斐波那契数列的第n项fib(n)的公式为: 它对应的递归过程为: long Fib(long n) if (n=1) return n; /终止递归条件 else Fib(n-1)+Fib(n-2); /递归步骤 ,3递归函数的一般实现方法 从程序设计的角度来说,递归过程必须解决两个问题:一是递归计算的公式,二是递归结束的条件。如上例中的问题,可以写成: 递归计算公式:Fib(n)=Fib(n1)+Fib(n2) n1 递归结束条件:Fib(n)=n n=1 凡是能够表示成上述式子的数学问题均可以用递归来实现,在递归函数中一般可采用双分支语句来实现: if (递归结束条件) return(递归终止值) else return(递归计算公式),11.4 函数的嵌套调用 在C语言中,所
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 14 圆明园的毁灭 公开课一等奖创新教案
- 化妆实训室安全培训课件
- 2025年秋部编版语文五上 21 古诗词三首(公开课一等奖创新教案++备课素材)
- 先从自己做起课件
- 勾股定理说课稿课件
- 勾股定理的逆定理课件
- 康复技术专业介绍
- 家庭教育学解读
- 灯箱制作技术分析
- 2025年轨道车司机(高级技师)职业技能鉴定考试题库(含答案)
- 2025年食药监局考试题库
- 2024年下半年黑龙江省嫩江铁路有限责任公司校招笔试题带答案
- 2025廉洁答题题库与答案
- 整本书阅读教学课件
- 企业法制讲座课件
- 【高朋律师事务所】RWA发展研究报告:法律、监管和前瞻(2025年)
- 汽车网销电话邀约话术培训
- 2025年福州房地产市场分析报告
- 《大学生心理健康教育》课程教案
- 音乐感知:从听觉到绘画
- 手抄报设计花边课件
评论
0/150
提交评论