2014年3月計(jì)算機(jī)二級(jí)C語(yǔ)言上機(jī)模擬試題

字號(hào):

為大家收集整理了《2014年3月計(jì)算機(jī)二級(jí)C語(yǔ)言上機(jī)模擬試題》供大家參考,希望對(duì)大家有所幫助!?。?BR>    給定程序中,函數(shù)fun的功能是:將a所指3×5矩陣中第k列的元素左移到第0 列,第k列以后的每列元素行依次左移,原來(lái)左邊的各列依次繞到右邊。
    例如,有下列矩陣:
    1 2 3 4 5
    1 2 3 4 5
    1 2 3 4 5
    若k為2,程序執(zhí)行結(jié)果為
    3 4 5 1 2
    3 4 5 1 2
    3 4 5 1 2
    請(qǐng)?jiān)诔绦虻南聞澗€處填入正確的內(nèi)容并把下劃線刪除,使程序得出正確的結(jié)果。
    注意:源程序存放在考生文件夾下的BLANK1.C中。
    不得增行或刪行,也不得更改程序的結(jié)構(gòu)!
    給定源程序:
    #include
    #define M 3
    #define N 5
    void fun(int (*a)[N],int k)
    { int i,j,p,temp;
    for(p=1; p<= __1__; p++)
    for(i=0; i    { temp=a[i][0];
    for(j=0; j< __2__ ; j++) a[i][j]=a[i][j+1];
    a[i][N-1]= __3__;
    }
    }
    main( )
    { int x[M][N]={ {1,2,3,4,5},{1,2,3,4,5},{1,2,3,4,5} },i,j;
    printf("The array before moving:\n\n");
    for(i=0; i    { for(j=0; j    for(i=0; i    { for(j=0; j
    解題思路:
    第一處:外循環(huán)p的終止變量的值,試題要求第k列左移,所以應(yīng)填:k。
    第二處:矩陣共N列,所以應(yīng)填:N-1。
    第三處:把存放在臨時(shí)變量temp中的值,放到a[i][N-1]中,所以應(yīng)填:temp。
    ***************************************************
    給定程序MODI1.C中函數(shù)fun的功能是:根據(jù)形參m的值(2≤m≤9〕,在m行m列的二維數(shù)組中存放如下所示規(guī)律的數(shù)據(jù),由main函數(shù)輸出。
    例如,若輸入 2 | 若輸入 4 則輸出: | 則輸出
    1 2 | 1 2 3 4
    2 4 | 2 4 6 8
    | 3 6 9 12
    | 4 8 12 16
    請(qǐng)改正程序函數(shù)中的錯(cuò)誤,使它能得出正確的結(jié)果。
    注意:不要改動(dòng)main函數(shù),不得增行或刪行,也不得更改程序的結(jié)構(gòu)!
    給定源程序:
    #include
    #define M 10
    int a[M][M] = {0} ;
    fun(int **a, int m)
    { int j, k ;
    for (j = 0 ; j < m ; j++ )
    for (k = 0 ; k < m ; k++ )
    a[j][k] = k * j ;
    }
    main ( )
    { int i, j, n ;
    printf ( " Enter n : " ) ; scanf ("%d", &n ) ;
    fun ( a, n ) ;
    for ( i = 0 ; i < n ; i++)
    { for (j = 0 ; j < n ; j++)
    printf ( "M", a[i][j] ) ;
    printf ( "\n" ) ;
    }
    }
    解題思路:
    第一處:在函數(shù)體fun中可知,a是一個(gè)字符串?dāng)?shù)組型變量,所以應(yīng)改為:fun(int a[][M], int m)。
    第二處:根據(jù)輸出的結(jié)果可知,應(yīng)改為:a[j][k]=(k+1)*(j+1);。
    ***************************************************
    函數(shù)fun的功能是:將a、b中的兩個(gè)兩位正整數(shù)合并形成一個(gè)新的整數(shù)放在c 中。合并的方式是:將a中的十位和個(gè)位數(shù)依次放在變量c的十位和千位上,b中的 十位和個(gè)位數(shù)依次放在變量c的個(gè)位和百位上。
    例如,當(dāng)a=45,b=12。調(diào)用該函數(shù)后,c=5241。
    注意: 部分源程序存在文件PROG1.C中。數(shù)據(jù)文件IN.DAT中的數(shù)據(jù)不得修改。
    請(qǐng)勿改動(dòng)主函數(shù)main和其它函數(shù)中的任何內(nèi)容,僅在函數(shù)fun的花括號(hào)中填入你編寫的若干語(yǔ)句。
    給定源程序:
    #include
    void fun(int a, int b, long *c)
    {
    }
    main()
    { int a,b; long c;
    printf("Input a, b:");
    scanf("%d%d", &a, &b);
    fun(a, b, &c);
    printf("The result is: %ld\n", c);
    NONO();
    }
    解題思路:
    本題是給出兩個(gè)兩位數(shù)的正整數(shù)分別取出各位上的數(shù)字,再按條件組成一個(gè)新數(shù)。
    取a十位數(shù)字的方法:a/10
    取a個(gè)位數(shù)字的方法:a
    參考答案:
    void fun(int a, int b, long *c)
    {
    *c=(a)*1000+(b)*100+(a/10)*10+(b/10);
    }