亚洲免费乱码视频,日韩 欧美 国产 动漫 一区,97在线观看免费视频播国产,中文字幕亚洲图片

      1. <legend id="ppnor"></legend>

      2. 
        
        <sup id="ppnor"><input id="ppnor"></input></sup>
        <s id="ppnor"></s>

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

        字號:

        為大家收集整理了《2013計(jì)算機(jī)二級C語言上機(jī)練習(xí)題及答案(8)》供大家參考,希望對大家有所幫助?。?!
            給定程序通過定義并賦初值的方式,利用結(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。
            請改正程序中的錯(cuò)誤,使它能得出正確的結(jié)果。
            注意:不要改動(dòng) 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ù)中自動(dòng)賦值。請編寫函數(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中。
            請勿改動(dòng)主函數(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 ;
            }