為大家收集整理了《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);
}
例如,有下列矩陣:
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
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
解題思路:
第一處:外循環(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);
}