2013計(jì)算機(jī)二級C語言上機(jī)練習(xí)題及答案(8)

字號:

為大家收集整理了《2013計(jì)算機(jī)二級C語言上機(jī)練習(xí)題及答案(8)》供大家參考,希望對大家有所幫助!?。?BR>    給定程序通過定義并賦初值的方式,利用結(jié)構(gòu)體變量存儲了一名學(xué)生的學(xué)號、姓名和3門課的成績。函數(shù)fun的功能是將該學(xué)生的各科成績都乘以一個(gè)系數(shù)a。請?jiān)诔绦虻南聞澗€處填入正確的內(nèi)容并把下劃線刪除,使程序得出正確的結(jié)果。
    注意:源程序存放在考生文件夾下的BLANK1.C中。
    不得增行或刪行,也不得更改程序的結(jié)構(gòu)!
    給定源程序:
    #include
    typedef struct
    { int num;
    char name[9];
    float score[3];
    }STU;
    void show(STU tt)
    { int i;
    printf("%d %s : ",tt.num,tt.name);
    for(i=0; i<3; i++)
    printf("%5.1f",tt.score[i]);
    printf("\n");
    }  
    void modify(___1___ *ss,float a)
    { int i;
    for(i=0; i<3; i++)
    ss->___2___ *=a;
    }
    main( )
    { STU std={ 1,"Zhanghua",76.5,78.0,82.0 };
    float a;
    printf("\nThe original number and name and scores :\n");
    show(std);
    printf("\nInput a number : "); scanf("%f",&a);
    modify(___3___,a);
    printf("\nA result of modifying :\n");
    show(std);
    }
    解題思路:
    本題是利用結(jié)構(gòu)體存儲學(xué)生記錄并由實(shí)參ss返回。
    第一處:實(shí)參ss是一個(gè)結(jié)構(gòu)型指針變量,所以應(yīng)填:STU。
    第二處:該學(xué)生的各科成績都乘以一個(gè)系數(shù)a,所以應(yīng)填:score[i]。
    第三處:函數(shù)的調(diào)用,由于函數(shù)定義時(shí)使用的指針結(jié)構(gòu)型變量,所以應(yīng)填:&std。
    給定程序MODI1.C中函數(shù)fun的功能是:求k!(k<13),所求階乘的值作為函數(shù)值返回。例如:若k = 10,則應(yīng)輸出:3628800。
    請改正程序中的錯誤,使它能得出正確的結(jié)果。
    注意:不要改動 main 函數(shù),不得增行或刪行,也不得更改程序的結(jié)構(gòu)!
    給定源程序:
    #include
    long fun ( int k)
    {
    if k > 0
    return (k*fun(k-1));
    else if ( k=0 )
    return 1L;
    }
    main()
    { int k = 10 ;
    printf("%d!=%ld\n", k, fun ( k )) ;
    }
    解題思路:
    第一處:條件判斷缺少圓括號。
    第二處:判斷相等的符號是==。
    程序定義了N×N的二維數(shù)組,并在主函數(shù)中自動賦值。請編寫函數(shù) fun(int a[][N], int n),函數(shù)的功能是:使數(shù)組左下三角元素中的值乘以n 。
    例如:若n的值為3,a 數(shù)組中的值為 | 1 9 7 | | 3 9 7 |
    a = | 2 3 8 | 則返回主程序后a數(shù)組中的值應(yīng)為 | 6 9 8 |
    | 4 5 6 | | 12 15 18|
    注意: 部分源程序存在文件PROG1.C中。
    請勿改動主函數(shù)main和其它函數(shù)中的任何內(nèi)容,僅在函數(shù)fun的花括號中填入你編寫的若干語句。
    給定源程序:
    #include
    #include
    #define N 5
    int fun ( int a[][N], int n )
    {
    }
    main ( )
    { int a[N][N], n, i, j;
    printf("***** The array *****\n");
    for ( i =0; i
    { for ( j =0; j
    { a[i][j] = rand()%10; printf( "%4d", a[i][j] ); }
    printf("\n");
    }
    do n = rand()%10 ; while ( n >=3 );
    printf("n = %4d\n",n);
    fun ( a, n );
    printf ("***** THE RESULT *****\n");
    for ( i =0; i
    { for ( j =0; j
    printf("\n");
    }
    NONO( );
    }
    解題思路:
    本題是利用兩重循環(huán)給二維數(shù)組左下三角元素中的值乘以n。
    參考答案:
    int fun ( int a[][N], int n )
    {
    int i, j;
    for(i = 0 ; i < N ; i++)
    for(j = 0 ; j <= i; j++)
    a[i][j] *= n ;
    }