第20页/共86页
7.6 函数的递归调用
定义
函数执行的过程中, 直接或者间接的调用 该函数本身,称为函 数的递归调用。
包括:回溯和递推 两个过程
int fun(int n) {
…
z=n*fun(n-1);
…}
第21页/共86页
引例:了解递归问题的回溯和递归两个过程
例7.6
有5个学生,
问第5个学生几岁,他说比第4个学生大2岁。
z=(x>y)?x,y; return z; }
第8页/共86页
复习
4. 函数调用过程
值 形参
实参
39
c = max( a , b ); (main函数)
int max(int x,int y) 9 { int z;
z=(x>y)?x,y; return z; }
第9页/共86页
复习
4. 函数调用过程
把函数头信息,如int max(int x,int y) 通知给编译系统,以便在调用时系统 按此检查调用的合法性。 c = max ( a , b );
第11页/共86页
复习
5. 函数声明 在 哪里 对 谁 进行声明: 主调函数内部对被调用函数进行声明
若main()调用max(),则在( )函数 内部,对( )函数进行声明。
第12页/共86页
复习
5. 函数声明 在 哪里 对 谁 进行声明: 主调函数内部对被调用函数进行声明
若main()调用max(),则在(main)函数 内部,对(max)函数进行声明。
第13页/共86页
复习
5. 函数声明 声明方法:函数原型(首部)加分号
void main() { int a,b;