- 1、本文档共89页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
出 题 方 向 函数的定义及调用 Return语句和函数返回值 参数的三种传递方式:值传递、地址传递和引用传递 递归函数的定义和调用 函数的重载 编译预处理的概念和特点 宏定义与宏调用,无参宏与有参宏的应用 包含文件的概念 函数调用示例1: #include iostream.h void swap(float x,float y) { float t; t=x; x=y; y=t; } void main(void) { float a=40,b=70; cout“a=”a‘\t’“b=”b‘\n’; swap(a,b); cout“a=”a‘\t’“b=”b‘\n’; } 分析: 在函数swap( )中交换了两个参数的值,但交换的结果并不改变实参的值,所以调用后a,b仍为原来的值。 #include iostream.h int maxi(int a,int b) { return ab?a:b; } float maxf(float a,float b) { return ab?a:b; } void main(void) { float x=3.4,y=5.6; char c1=‘a’,c2=‘b’; // ‘a’的ascii码为97,‘b’为98 int i=20,j=30; coutmaxi(x,y)‘\t’; //类型不匹配,警告,将float强制转换成int coutmaxf(x,y)‘\t’; coutmaxi(c1,c2)‘\t’; coutmaxf(c1,c2)‘\t’; coutmaxi(i+j,45+y)‘\t’; //类型不匹配,警告 coutmaxf(i+j,45+y)‘\n’; } #include iostream.h void main(void) { int a,b; int max(int,int); //函数的原型说明 cout“输入两个整数!”; cinab; cout“大数是:”max(a,b)‘\n’; } int max(int x,int y) //函数定义 { return(xy?x:y); } 例7:求5!和10! 1 n=0 n= 1 n=1 n*(n-1)! n1 #include iostream.h long int f(int n) { if(n==0 || n==1) return 1; // 递归结束条件 else return n*f(n-1); //递归调用 } void main(void) { cout“5!=”f(5)‘\t’“10!=”f(10)‘\n’; } 源程序: #include iostream.h #include iomanip.h long int f(int n) { if(n==1 || n==2) return(1); else return f(n-1)+f(n-2); } void main(void) { int i; for(i=1;i=40;i++) { coutsetw(10)f(i); if(i%4==0) cout‘\n’; } } 1. 递归公式; 2. 递归的结束条件; 在递归程序中一定要有递归结束条件,否则,在执行程序时将产生无穷尽的递归调用。 3. 递归的约束条件。 #include iostream.h int i=100; // i为全局变量 void main(void) { int i=18,j=50; // i,j为局部变量 ::i=::i+4; // 访问全局变量i j=::i+i; //访问全局变量i和局部变量i cout“::i=”::i‘\n’; cout“i=”i‘\n’; cout“j=”j‘\n’; } #include iostream.h int t() { stati
文档评论(0)