一.实验目的:
1.掌握函数的定义和使用方法;
2.掌握函数调用的方法;
3.掌握函数参数传递的机制;
4. 掌握函数重载的方法。
二.实验题目
1.求三个自然数m和n和p的最大公约数和最小公倍数。
2.编程求下式的值:n1+n2+n3+n4+…+n8 其中n=1, 2, 3…,编写函数时,设置参数n的默认值为2。
3.使用函数重载的方法定义四个同名函数max,分别求取两个整数、三个整数,两个双精度数、三个双精度数的最大值。
第一题算法设计:
1. 首先输入三个数m,n,p,求出m,n的最大公约数a;
2. 求a与p的最大公约数b,得出三个数的最大公约数。
3. 利用相同原理,先求出两个数的最小公倍数,然后在求出三个数的最小公倍数。
三.程序源代码:
#include
using namespace std;
int func(int a, int b);//求两个数的最大公约数
int func2(int a, int b);//求两个数的最小公倍数
int main()
{
intm,n,p;//用来存储输入的三个数
cout<<"请输入三个要求的数字:"<<endl;
cin>>m>>n>>p;
inti = func(m,n);
intj = func(p,i);//求三个数的最大公约数
intk = func2(m,n);
intl = func2(k,p);//求三个数的最小公倍数
cout<<"最大公约数为:"<<j<<endl;
cout<<"最小公倍数为:"<<l<<endl;//输出
return0;
}
int func(int a, int b)
{
if(a%b==0) return b;
returnfunc(b,a%b);//递归
}
int func2(int a, int b)
{
return(a*b)/(func(a,b));//递归
}
四.程序运行结果:
请输入三个要求的数:
24 8 12
最大公约数:4
最大公倍数24
Press any key to continue_
五.结果分析:
该题目中用到了递归,涉及到函数之间的调用和函数自身的调用,做了此题后,我充分认识到函数调用的神奇性质,让我在程序设计的道路上更进一步。
第二题算法设计:
1. 直接调用带默认参数的子函数对变量m赋值并且输出。
源代码:
# include
# include
using namespace std;
int f(int n=2)//子函数用来求2的1次幂到10次幂,带默认参数整形2
{
int sum = 0;
for(int i=1; i<=10; i++)
sum+=pow(n,i);
return sum;
}
int main()
{
int m;
m = f();//调用带默认参数的子函数
cout<<"2的1次幂到10次幂的和为:"<<m<<endl;
return 0;
}
程序运行结果:
2的1次幂到10次幂的和为2046
Press any key to continue_
总结:
此段代码非常简单,目的是为了理解带默认参数的函数调用,带默认参数的函数在调用时就不用输入参数了,而可以直接调用,但是如果传入两个默认参数,则不允许第一个使用默认参数而第二个不使用默认参数。另外在函数声明时应该给出默认值,否则编译报错重复定义参数。
第三题算法设计:
1.首先输入三个整数,用函数求出前两个数的最大值,然后再求出三个整数的最大值。可以用三目运算符搞定。最后在输出。
代码如下:
#include
using namespace std;
int max(int a, int b);//求两整数的最大值
int max(int a, int b, int c);//求三个整数的最大值
double max(double a, double b);//~~~~~~
double max(double a, double b, double c);//~~~~~
int main()
{
int a, b, c;
double a1, b1, c1;
cout<<"请输入三个整数"<<endl;
cin>>a>>b>>c;
cout<<"前两个整数最大的是:"<<max(a, b)<<endl;
cout<<"三个整数最大的是:"<<max(a, b, c)<<endl;
cout<<"--------------------------------"<<endl;
cout<<"请输入三个浮点数:"<<endl;
cin>>a1>>b1>>c1;
cout<<"前两个浮点数数最大的是:"<<max(a1, b1)<<endl;
cout<<"三个浮点数数最大的是:"<<max(a1, b1, c1)<<endl;
return 0;
}
int max(int a, int b) { return a>=b?a:b; }
int max(int a, int b, int c){
int tmp;
if(a>=b) tmp = a;
else tmp = b;
return tmp>=c?tmp:c;
}
double max(double a, double b){ return a>=b?a:b; }
double max(double a, double b, double c)
{
double tmp;
if(a>=b) tmp = a;
else tmp = b;
return tmp>=c?tmp:c;
}
运行结果如下:
总结:
比较大小只不过就是函数调用而已,使用三目运算符不过是一个简单的应用罢了,没有什么技巧而言,唯一需要注意的是double类型的数据只支持六位有效位,位数过多会丢失数据,值得注意。
通过以上三个题目,我更加了解了C++中函数的使用,明白了函数的调用方式和传入参数的方法。