实验四 函数和数组
实验任务1
不可以 函数返回值只有一个 但一元二次方程有两个根
实验任务2
//利用局部static变量计算阶乘 #include<stdio.h> long long fac(int n);//函数声明 int main(){ int i,n; printf("Enter n:"); scanf("%d",&n); for(i=1;i<=n;++i) printf("%d!=%lld\n",i,fac(i)); return 0; } //函数定义 long long fac(int n){ static long long p=1; printf("p=%lld\n",p); p=p*n; return p; }
//练习:局部static变量特征 #include<stdio.h> int func(int,int); int main(){ int k=4,m=1,p1,p2; p1 = func(k,m); p2 = func(k,m); printf("%d,%d\n",p1,p2); return 0; } int func(int a,int b){ static int m=0,i=2; i += m+1; m = i+a+b; return (m); }
理论分析结果与实验运行结果一致
理论分析:第一次 i=3,m=8 返回m=8,p1=8
第二次i=12,m=17 返回m=17,p2=17
实验运行结果:
特性:变量始终存在,不被其他函数使用,且保存上次结果
实验任务3
//寻找两个整数之间所有素数(包括这两个整数),把结果保存在数组bb中,函数返回素数的个数 //例如,输入6和21,则输出为7 11 13 17 19 #include<stdio.h> #define N 1000 int fun(int n,int m,int bb[N]){ int i,j,k=0,flag; for(j=n;j<=m;j++){ flag=1; for(i=2;i<j;i++) if(j%i==0){ flag=0; break; } if(flag==1) bb[k++]=j; } return k; } int main(){ int n=0,m=0,i,k,bb[N]; scanf("%d",&n); scanf("%d",&m); for(i=0;i<m-n;i++) bb[i]=0; k=fun(n,m,bb); for(i=0;i<k;i++) printf("%4d",bb[i]); return 0; }
实验任务4
//f(x)=2^n-1 #include<stdio.h> long long fun(int n);//函数声明 int main(){ int n; long long f; while(scanf("%d",&n)!=EOF){ f=fun(n)-1;//函数调用 printf("n=%d,f=%d\n",n,f); } return 0; } //函数定义 int long long fun(int n){ int k; if(n==1) k=2; else k=2*fun(n-1); return k; }
PS:这里的运行结果有误
第一次代码为 k=2*fun(n-1)-1,然后发现因为这个结果是不断保存并带入下一次计算的 所以表达式不对
第二次代码改为 k=2*fun(n-1)+1,发现这可以运行到31 但是32的运行结果有错误
最后我改为用此方法求 2^n,在主函数中再减去1,方法可行,第一次运行结果无问题
该次运行32的运行结果又出现了问题 不明白 求解
实验任务5
#include<stdio.h> void draw(int n,char symbol);//函数声明 #include<stdio.h> int main(){ int n,symbol; while(scanf("%d %c",&n,&symbol)!=EOF){ draw(n,symbol);//函数调用 printf("\n"); } return 0; } //函数定义 void draw(int n,char symbol){ int line,i,m; for(line=1;line<=n;line++){ for(i=1;i<=n-line;i++){ printf(" "); } for(m=1;m<=2*line-1;m++){ printf("%c",symbol); } printf("\n"); } }
问题:关于实验4 尚存问题 详细见实验任务4