C语言程序设计PPt第三章函数课件.ppt
- 【下载声明】
1. 本站全部试题类文档,若标题没写含答案,则无答案;标题注明含答案的文档,主观题也可能无答案。请谨慎下单,一旦售出,不予退换。
2. 本站全部PPT文档均不含视频和音频,PPT中出现的音频或视频标识(或文字)仅表示流程,实际无音频或视频文件。请谨慎下单,一旦售出,不予退换。
3. 本页资料《C语言程序设计PPt第三章函数课件.ppt》由用户(晟晟文业)主动上传,其收益全归该用户。163文库仅提供信息存储空间,仅对该用户上传内容的表现方式做保护处理,对上传内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知163文库(点击联系客服),我们立即给予删除!
4. 请根据预览情况,自愿下载本文。本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
5. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007及以上版本和PDF阅读器,压缩文件请下载最新的WinRAR软件解压。
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 语言程序设计 PPt 第三 函数 课件
- 资源描述:
-
1、第三章第三章 函数函数C+语言程序设计1C+语言程序设计本章主要内容本章主要内容l函数的定义、声明和调用函数的定义、声明和调用l函数间的参数传递函数间的参数传递l内联函数内联函数l带默认形参值的函数带默认形参值的函数l函数重载函数重载lC+系统函数系统函数2C+语言程序设计函数的定义函数的定义l函数是面向对象程序设计中,对功能的函数是面向对象程序设计中,对功能的抽象抽象l函数定义的语法形式函数定义的语法形式类型标识符 函数名(形式参数表)语句序列函数的声明与使用是被初始化的内部变量,寿命和可见性仅限于函数内部若无返回值,写voiddoubledouble power(double x,int
2、n)power(double x,int n)double val=1.0;double val=1.0;while(nwhile(n -)-)val=valval=val*x;x;return(val);return(val);3C+语言程序设计函数的调用函数的调用l调用前先声明函数原型:调用前先声明函数原型:在调用函数中,或程序文件中所有函数之外,按如下形式说明:类型标识符 被调用函数名(含类型说明的形参表);l调用形式调用形式 函数名(实参列表)l嵌套调用嵌套调用函数可以嵌套调用,但不允许嵌套定义。递归调用函数直接或间接调用自身。函数的声明与使用4C+语言程序设计例例3-1编写一个求编写
3、一个求x的的n次方的函数次方的函数#include iostreaminclude doubledouble power(double x,int n);power(double x,int n);int main()int main()cout5 to the power 2 is cout5 to the power 2 is powerpower(5,2)endl;(5,2)endl;doubledouble power(double x,int n)power(double x,int n)double val=1.0;double val=1.0;while(n-)while(n-)
4、val=valval=val*x;x;return(val);return(val);函数的声明与使用5C+语言程序设计运行结果:运行结果:5 5 to the power 2 is 25to the power 2 is 25例例3-1编写一个求编写一个求x的的n次方的函数次方的函数函数的声明与使用6C+语言程序设计例例3-2 数制转换数制转换题目:题目:输入一个输入一个8 8位二进制数,将其转换为十进位二进制数,将其转换为十进制数输出。制数输出。例如:例如:0 0110111010010012 2 =0 0(2(27 7)+1+1(2(26 6)+1+1(2(25 5)+0+0(2(24
5、4)+1(21(23 3)+)+0 0(2(22 2)+0(2)+0(21 1)+1(2)+1(20 0)=1051051010 所以,所以,如果输入如果输入0 011010011101001,则应输出,则应输出105105函数的声明与使用7#include iostreaminclude double double powerpower(double x,int n);(double x,int n);/声明函数原型声明函数原型powerpowerint main()int main()int i;int i;int value=0;int value=0;char ch;char ch;c
6、out Enter an 8 bit binary number ;cout=0;i-)for(i=7;i=0;i-)cin ch;cin ch;if(ch=1)if(ch=1)value+=int(value+=int(powerpower(2,i);(2,i);/调用函数调用函数powerpower cout Decimal value is valueendl;cout Decimal value is valueendl;double double powerpower(double x,int n)(double x,int n)/声明函数声明函数powerpower double
7、val=1.0;double val=1.0;while(n-)while(n-)val val*=x;=x;return(val);return(val);运行结果:运行结果:Enter an 8 bit binary number Enter an 8 bit binary number 0110100101101001Decimal value is 105Decimal value is 10588C+语言程序设计例例3-3编写程序求编写程序求的值的值其中其中arctanarctan用如下形式的级数计算:用如下形式的级数计算:直到级数某项绝对值不大于直到级数某项绝对值不大于1010-1
8、5-15为止;为止;和和x x均为均为doubledouble型。型。函数的声明与使用2391arctan451arctan16753)arctan(753xxxxx9#includeincludeiostream.hintint main()main()double a,b;double a,b;double double arctanarctan(double(double x);/x);/函数原型声明函数原型声明 a=16.0a=16.0*arctanarctan(1/5.0);(1/5.0);b=4.0 b=4.0*arctanarctan(1/239.0);(1/239.0);/注意
9、:因为整数相除结果取整,注意:因为整数相除结果取整,/如果参数写如果参数写1/51/5,1/2391/239,结果就都是,结果就都是0 0 coutcoutPI=a-bPI=a-b1e-15)while(e/i1e-15)f=e/i;f=e/i;r=(i%4=1)?r+f:r=(i%4=1)?r+f:r-fr-f;e=e e=e*sqrsqr;i+=2;i+=2;return r;return r;运行结果:运行结果:PI=3.14159PI=3.141591111C+语言程序设计例例3-4l寻找并输出寻找并输出1199911999之间的数之间的数m m,它满足它满足m m、m m2 2和和m
10、 m3 3均为回文数。均为回文数。回文:各位数字左右对称的整数。例如:11满足上述条件 112 2=121,113 3=1331。l分析:分析:10取余的方法,从最低位开始,依次取出该数的各位数字。按反序重新构成新的数,比较与原数是否相等,若相等,则原数为回文。-参见例参见例2-6函数的声明与使用12#include include iostream.hintint main()main()boolbool symmsymm(long(long n);n);long m;long m;for(m=11;m1000;m+)for(m=11;m1000;m+)if(if(symmsymm(m)&(
11、m)&symmsymm(m(m*m)&m)&symmsymm(m(m*m m*m)m)coutcoutm=m mm=m m*m=mm=m*m m m m*m m*m=mm=m*m m*mmendlendl;1313boolbool symm(longsymm(long n)n)long i,m;long i,m;i=n;m=0;i=n;m=0;while(while(i i)/等价于等价于while(i!=0)while(i!=0)m=m=m m*10+i%1010+i%10;/对求出的每一位累加对求出的每一位累加 i=i/10 ;i=i/10 ;return(m=n);return(m=n)
12、;1414运行结果:运行结果:m=11 mm=11 m*m=121 mm=121 m*m m*m=1331m=1331m=101 mm=101 m*m=10201 mm=10201 m*m m*m=1030301m=1030301m=111 mm=111 m*m=12321 mm=12321 m*m m*m=1367631m=13676311515C+语言程序设计例例3-5计算如下公式,并输出结果:计算如下公式,并输出结果:其中其中r r、s s的值由键盘输入。的值由键盘输入。sinsin x x的近似的近似值按如下公式计算,计算精度为值按如下公式计算,计算精度为1010-6-6:函数的声明与
13、使用222222r)sin(21r)(sin)(sinssrssrk当当1121753)!12()1(!7!5!3!1sinnnnnxxxxxx16#include include iostream.h#include#includecmath.hintint main()main()double k,r,s;double k,r,s;double double tsintsin(double(double x);x);coutcoutr=;r;r;coutcouts=;s;s;if(r if(r*r=sr=s*s)s)k=k=sqrt(sqrt(tsintsin(r(r)*tsintsin(
14、r)+(r)+tsintsin(s(s)*tsintsin(s(s););else else k=k=tsintsin(r(r*s)/2;s)/2;coutcoutkk=p);)=p);return g;return g;运行结果:r=5s=81.37781181121753)!12()1(!7!5!3!1sinnnnnxxxxxxg:存放累加和t:存放任一项当前项 =(-1)*前一项*X*X/(2*n-1)/(2*n-2)18C+语言程序设计例例3-6投骰子的随机游戏投骰子的随机游戏每个骰子有六面,点数分别为每个骰子有六面,点数分别为1 1、2 2、3 3、4 4、5 5、6 6。游戏者在程
15、序开始时输入一个无符号整数,作为产生游戏者在程序开始时输入一个无符号整数,作为产生随机数的种子。随机数的种子。每轮投两次骰子,第一轮如果和数为每轮投两次骰子,第一轮如果和数为7 7或或1111则为胜,则为胜,游戏结束;和数为游戏结束;和数为2 2、3 3或或1212则为负,游戏结束;和数则为负,游戏结束;和数为其它值则将此值作为自己的点数,继续第二轮、第为其它值则将此值作为自己的点数,继续第二轮、第三轮三轮.直到某轮的和数等于点数则取胜,若在此前直到某轮的和数等于点数则取胜,若在此前出现和数为出现和数为7 7则为负。则为负。由由rolldicerolldice函数负责模拟投骰子、计算和数并输函
16、数负责模拟投骰子、计算和数并输出和数。出和数。函数的声明与使用19#include include iostream.h#include#include cstdlib.hintint rolldicerolldice(void(void););intint main()main()intint gamestatus,sum,mypointgamestatus,sum,mypoint;unsigned seed;unsigned seed;coutcoutPlease enter an unsigned integer:;seed;/seed;/输入随机数种子输入随机数种子 srand(see
17、dsrand(seed);/);/将种子传递给将种子传递给rand()rand()sum=sum=rolldicerolldice();/();/第一轮投骰子、计算和数第一轮投骰子、计算和数2020 switch(sum)switch(sum)case 7:/case 7:/如果和数为如果和数为7 7或或1111则为胜则为胜,状态为状态为1 1 case 11:case 11:gamestatusgamestatus=1;=1;break;break;case 2:/case 2:/和数为和数为2 2、3 3或或1212则为负则为负,状态为状态为2 2 case 3:case 3:case 1
18、2:case 12:gamestatusgamestatus=2;=2;break;break;default:default:/其其他他情况情况,游戏尚无结果游戏尚无结果,状态为状态为0,0,记下点数记下点数,为下一轮做准备为下一轮做准备 gamestatusgamestatus=0;=0;mypointmypoint=sum ;=sum ;coutcoutpoint is point is mypointmypointendlendl;break;break;2121 while(gamestatuswhile(gamestatus=0)=0)/只要状态仍为只要状态仍为 0,0,就继续进行
19、下一轮就继续进行下一轮 sum=sum=rolldicerolldice();();if(sum=if(sum=mypointmypoint)/某轮的和数等于点数则取胜某轮的和数等于点数则取胜,状态置为状态置为1 1 gamestatusgamestatus=1=1 else else if(sum=7 )/if(sum=7 )/出现和数为出现和数为7 7则为负则为负,状态置为状态置为2 2 gamestatusgamestatus=2;=2;/当状态不为当状态不为0 0时上面的循环结束时上面的循环结束,以下程序段输出游戏结果以下程序段输出游戏结果 if(if(gamestatusgamest
20、atus=1 )=1 )coutcoutplayer winsn;player winsn;else else coutcoutplayer losesn;player losesn;2222lrandrand函数原型:int rand(void);所需头文件:功能和返回值:求出并返回一个伪随机数lsrandsrand函数原型:void srand(unsigned int seed);参数:seed产生随机数的种子。所需头文件:功能:为使rand()产生一序列伪随机整数而设置起始点。使用1作为seed参数,可以重新初化rand()。2323intint rolldice(voidrolldi
21、ce(void)/投骰子、计算和数、输出和数投骰子、计算和数、输出和数 intint die1,die2,worksum;die1,die2,worksum;die1=1+rand()%6;die1=1+rand()%6;die2=1+rand()%6;die2=1+rand()%6;worksumworksum=die1+die2;=die1+die2;coutcoutplayer rolled player rolled die1+die2=die1+die2=worksumworksumendlendl;return return worksumworksum;2424运行结果运行结果2
22、 2:Please enter an unsigned integer:23Please enter an unsigned integer:23player rolled 6+3=9player rolled 6+3=9point is 9point is 9player rolled 5+4=9player rolled 5+4=9player winsplayer wins2525C+语言程序设计函数调用的执行过程函数调用的执行过程函数的声明与使用main()调fun()结束fun()返回保存:返回地址当前现场恢复:主调程序现场返回地址26C+语言程序设计嵌套调用嵌套调用函数的声明与使用
23、main调fun1()结束fun1()调fun2()返回fun2()返回27C+语言程序设计例例3-6 输入两个整数,求平方和。输入两个整数,求平方和。#include include iostream.hintint main()main()intint a,b;a,b;intint fun1(int fun1(int x,intx,int y);y);cincinab;ab;coutcoutaa、b b的平方和:的平方和:fun1fun1(a,b)(a,b)endlendl;函数的声明与使用28intint fun1fun1(int(int x,intx,int y)y)intint fu
24、n2fun2(int m);(int m);return(fun2(x)+fun2(y);return(fun2(x)+fun2(y);intint fun2fun2(int m)(int m)return(m return(m*m);m);运行结果:运行结果:3 43 4a a、b b的平方和:的平方和:25252929C+语言程序设计递归调用递归调用l函数直接或间接地调用自身,称为递归调用。l递归过程的两个阶段:递推:4!=43!3!=32!2!=21!1!=10!0!=1未知 已知回归:4!=43!=243!=32!=62!=21!=21!=10!=10!=1未知未知 已知已知函数的声明
25、与使用30C+语言程序设计例例3-8 求求n!分析:计算n!的公式如下:这是一个递归形式的公式,应该用递归函数实现。函数的声明与使用)0()!1()0(1!nnnnn31源程序:源程序:#include include iostream.hlonglong facfac(int(int n)n)long f;long f;if(n0)if(n0)coutcoutn0,data error!n0,data error!endlendl;else if(n=0)f=1;else if(n=0)f=1;else f=else f=facfac(n-1)(n-1)*n;n;return(f);retu
展开阅读全文