實驗四 函式和陣列
阿新 • • 發佈:2020-11-29
實驗任務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