函数章节
函数章节
函数的作用
函数编写好后,可以被重复使用,使用时之关心函数的功能和使用方法不必关心函数的功能的具体实现。这样有利于代码的重用可以提高开发效率、增强程序的可靠性,也便于分工合作和修改维护。
函数重载
函数的值传递
当发生函数调用时仅仅只将实参(实际参数)的值传递给函数的形参(函数的形式参数)在函数内计算,当退出函数时实参的值并不会发生改变。
例如:
#include<iostream>
using namespace std;
swap(int a,int b)
{
int t=a;
a=b;
b=t;
cout<<"a="<<a<<' '<<"b="<<b<<endl;
}
int main()
{
int x,y;
cout<<"请输入x,y" <<endl;
cin>>x>>y;
swap(x,y);
cout<<"x="<<x<<' '<<"y="<<y<<endl;
return 0;
}
这样就能看出在函数内的形式参数a,b值发生了改变,而对于实际参数x,y的值并未发生改变,这就是函数的值传递。
函数的地址传递
函数的地址传递就是利用&(取地址符)将实参的地址传递给函数,地址中存放着数据,可以通过修改实参地址中的数据达到修改实参值的目的。
例如:
#include<iostream>
using namespace std;
swap(int &a,int &b)
{
int t=a;
a=b;
b=t;
cout<<"a="<<a<<' '<<"b="<<b<<endl;
}
int main()
{
int x,y;
cout<<"请输入x,y" <<endl;
cin>>x>>y;
swap(x,y);
cout<<"x="<<x<<' '<<"y="<<y<<endl;
return 0;
}
这样就实现了函数的地址传递,从代码运行结果可以看出实参的值已经被修改了。
递归函数
递归函数就可以直接或间接的调用自身的函数。其实很多需要重复相同算法的计算就可以用递归也可以用循环。例如计算n!,n!=n*[(n-1)!];这时就会有重复的步骤计算(n-1)!。
代码如下:
#include<iostream>
using namespace std;
int fac(int n)
{
if(n==1)
{
return 1;
}
else
{
return n*fac(n-1);
}
}
int main()
{
int n;
cout<<"输入要计算的阶乘"<<endl;
cin>>n;
cout<<n<<"!结果是"<<fac(n)<<endl;
return 0;
}
就像这样一个函数调用自身,这就是递归函数,它可以简化很多复杂的循环计算代码。