国家二级C语言机试(操作题)模拟试卷365
程序填空题
1.给定程序中,函数fun的功能是:有N×N矩阵,将矩阵的外围元素顺时针旋转。操作顺序是:首先将第一行元素的值存入临时数组r,然后使第一列成为第一行,最后一行成为第一列,最后一列成为最后一行,临时数组中的元素成为最后一列。
例如,若N=3,有下列矩阵:
1 2 3 计算结果为 7 4 1
4 5 6 8 5 2
7 8 9 9 6 3
请在程序的下划线处填入正确的内容并把下划线删除,使程序得出正确的结果。
注意:源程序存放在考生文件夹下的BLANK1.C中。
不得增行或删行,也不得更改程序的结构!
1 #include<stdio.h>
2 #define N 4
3 void fun(int(*t)[N])
4 { int j,r[N];
5 for(j=0;j<N;j++)r[j]=t[0][j];
6 for(j=0;j<N;j++)
7 /**********found**********/
8 t[0][N-j-1]=t[j][__1__];
9 for(j=0;j<N;j++)
10 t[j][0]=t[N-1][j];
11 /**********found**********/
12 for(j=N-1;j>=0;__2__)
13 t[N-1][N-1-j]=t[j][N-1];
14 for(j=N-1;j>=0;j–)
15 /**********found**********/
16 t[j][N-1]=r[__3__];
17 }
18 main()
19 {int t[][N]={21,12,13,24,25,16,47,38,29,11,32,54,42,21,33,10},i,j;
20 printf(’’\nThe original array:\n’’);
21 for(2=0;i<N;i++)
22 {for(j=0;j<N;j++)printf(’’%2d”,t[i][j]);
23 printf(’’\n’’);
24 }
25 fun(t);
26 printf(’’\nThe result is:\n’’);
27 for(i=0;i<N;i++)
28 { for(j=0;j<N;j++)printf(’’%2d’’,t[i][j]);
29 printf(’’\n’’);
30 }
31 }
(1)0 (2)j– (3)j
解析:第一空:由审题分析可知,此处是使第一列成为第一行,即把第一列元素移动到第一行,第一列元素是“t[j][0]”,第一行元素是“t[0][N-j-1]”,故第一空处应为“0”。
第二空:第四个循环是最后一列成为最后一行,即将最后一列移动到最后一行,“for(j=N-1;j>=0;__2__)”循环变量i从N-1开始,到0结束,共循环N次,故j每次减1,第三空处是“i–”。
第三空:最后一个循环将临时数组中的元素成为最后1列,即“t[=i][N-1]=r[j]”,故第三空处应为“j”。
程序修改题
2.给定程序MODI1.C中函数fun的功能是:求出s所指字符串中最后一次出现的t所指子字符串的地址,通过函数值返回,在主函数中输出从此地址开始的字符串:若未找到,则函数值为NULL。
例如,当字符串中的内容为’’abcdabfabcdx\\
(1)a=NULL; (2)if(*r==*p)
解析:函数功能是求得字符串中某子串最后一次出现的地址。(1)第一个标识下面:语句“a=Null;”中的Null未定义。NULL代表空值,但程序中写成了Null。所以,改成“a=NULL;”。(2)程序的主体是二重循环,其中外循环使指针s逐个指向字符串的字符,直到遇到串结束符退出循环,内循环检查指针p与r所指字符串是否匹配。因为这里p、r是指针,如果使用判断表达式“if(r==p)”,那么比较的是地址,而题目要求比较它们所指的字符。所以,改为:“if(*r==*p)”。
程序设计题
3.请编写函数fun,函数的功能是:将M行N列的二维数组中的数据,按列的顺序依次放到一维数组中。
例如,二维数组中的数据为:
33 33 33 33
44 44 44 44
55 55 55 55
则一维数组中的内容应是:
33 44 55 33 44 55 33 44 55 33 44 55。
注意:部分源程序在文件PROGl.C中。
请勿改动主函数main和其他函数中的任何内容,仅在函数fun的花括号中填入你编写的若干语句。
1 #include<stdio.h>
2 void fun(int s[][10],int b[],int*n,int mm,int nn)
3 {
4 }
5 main()
6 {int w[10][10]={{33,33,33,33},{44,44,44,44},{55,55,55,55}},i,j;
7 int a[100]=(0),n=0;void NONO();
8 printf(’’The matrix:\n’’);
9 for(i=0; i<3;i++)
10 {for(j=0;j<4;j++) printf(’’%3d’’,w[i][j]);
11 printf(’’\n’’);}
12 fun(w,a,&n,3,4);
13 printf(’’The A array:\n’’);
14 for(i=0;i<n;i++) printf(’’%3d’’,a[i]);printf(’’\n\n’’);
15 NONO();}
16 void NONO()
17 {/*请在此函数内打开文件,输入测试数据,调用fun函数,输出数据,关闭文件。 */
18 FILE *rf,*wf;int i,j,k;
19 int w[10][10],a[100],n=0,mm,nn;
20 rf=fopen(’’in.dat’’,’’r’’);
21 wf=fopen(’’out.dat’’,’’w’’);
22 for(k=0;k<5;k++){
23 fscanf(rf,’’%d%d’’,&mm,&nn);
24 for(i=0;i<mm;i++)
25 for(j=0; j<nn ; j++) fscanf(rf,’’%d’’,&w[i][j]);
26 fun(w,a,&n,mm,nn);
27 for(i=0;
本文档预览:3600字符,共3973字符,源文件无水印,下载后包含无答案版和有答案版,查看完整word版点下载