1. 程式人生 > 實用技巧 >實驗四 函式與陣列

實驗四 函式與陣列

實驗一:

在這個應用中,一元二次方程的根可以設計成以函式返回值的方式返回給主調函式。

因為隨時改變的值可以設定成引數。

實驗二:

(1)

// 利用區域性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; p = p*n; return p; }

增加一行程式碼後,測試結果截圖:

(2)

// 練習:區域性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); }

理論分析結果與實驗執行結果不一致。

總結static變數的特性:靜態區域性變數是在編譯時賦初值,在程式執行期間,一旦儲存單元中的值改變,就不會再執行賦初值的語句,未賦初值的變數其值為0.

實驗三:

//尋找兩個整數之間的所有素數(包括這兩個整數),把結果儲存在陣列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!=0&&j!=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; }

實驗四:

#include <stdio.h>
long long fun(int n);   // 函式宣告 

int main() {
 int n;
 long long f;
 
 while(scanf("%d", &n) != EOF) {
  f = fun(n);  // 函式呼叫 
  printf("n = %d, f = %lld\n", n, f);
 }
 
 return 0;
}
long long fun(int n){
 long long z;
 if(n==0)
  return 0;
 else if(n==1)
  return 1;
 else
  z=fun(n-1)*2+1;
 return z;
}

實驗五

#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 i,m;
    for(m=1;m<=n;m++)
    {
        for(i=1;i<=n-m;i++)
        {
            printf(" ");
        }
        for(i=1;i<=2*m-1;i++)
        {
        printf("%c",symbol);
        }
    printf("\n");
    }

}