函数的定义:定义时需要由返回类型和函数名构成(函数需要先定义后使用)
函数的传值
传值方式从实参到形参(只能是单方向的传递 函数的变量只能在该函数内使用 调用该函数时若需要输出该函数的值只能在函数内输出)
eg:调用fac()函数需要得到result
第一种方式在调用函数中打印result的值
第二种是在主函数中打印fac()函数的结果且在fac函数中要返回result
#include<stdio.h>
int fac(int n){
int i;
long result=1;
for(i=1;i<=n;i++){
result=i*result;
}
printf("%d",result);
return 0;
}
int main(){
int n;
scanf("%d",&n);
fac(n);
return 0;
}
求和实例:
在打印求和的值是调用和函数将实参s传给形参s 且形参的变化不影响实参的变化
在开始是我没有给sum附初值0结果执行结果总是要比实际结果大1 然后给sum附值以后执行正确
#include<stdio.h>
int sum(int s){
int i,sum=0;
for(i=1;i<=s;i++){
sum=sum+i;
}
return sum;
}
int main(){
int s;
scanf("%d",&s);
printf("%d",sum(s));
return 0;
}
函数也可以先声明然后再调用的时候写函数
求和实例将上面代码稍微改了一下
#include<stdio.h>
void sum(int);
int main(){
int s;
scanf("%d",&s);
sum(s);
return 0;
}
void sum(int s){
int i,sum=0;
for(i=1;i<=s;i++){
sum=sum+i;
}
printf("%d",sum);
}
函数中数组的传递(数组在传递过程中只是数组地址的传递 地址的变化引起值的变化)
数组交换实例
a[0] 12
a[1] 34
进入swap函数后
s[0] 34——a[0]
s[1] 12——a[1]
#include<stdio.h>
void swap(int s[]){
int temp;
temp=s[0];
s[0]=s[1];
s[1]=temp;
}
int main(){
int a[2]={12,34};
int i;
swap(a);
for(i=0;i<2;i++){
printf("%-3d",a[i]);
}
return 0;
}
最大公约数编程(辗转相除法)
#include<stdio.h>
void m(int a,int b){
int n=0;
while(a%b!=0){
n=a%b;
a=b;
b=n;
}
printf("%d",n);
}
int main(){
int a,b;
scanf("%d %d",&a,&b);
m(a,b); //定义最大公约数函数
}
函数的递归调用
递归法计算阶乘
实质在调用fac()函数中使用fac(n-1)进行递归调用(循环)
#include<stdio.h>
int fac(int n){
if(n==1){
return 1;
}
else{
return n*fac(n-1);
}
}
int main(){
int n;
scanf("%d",&n);
printf("%d",fac(n));
return 0;
}