首页 > 全部 > 二级C语言 > 国家二级C语言机试(操作题)模拟试卷365

国家二级C语言机试(操作题)模拟试卷365

本单篇文档共3973字,内容预览3600字,预览为有答案版,源文件无水印,下载后包含无答案空白卷版和有答案版,同时也有计算机类NCRE全国计算机二级整科真题模拟题,讲义课件,思维导图,易错高频题等下载。
二级C语言 章节练习 5023人下载
价格: 1.00 原价:¥9.00
收藏

国家二级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版点下载

剩余未完,查看全文
收藏
国家二级C语言机试(操作题)模拟试卷365

推荐资源

客服

扫码添加客服微信

热线

官方客服

如遇问题,请联系客服为您解决

电话客服:

客服微信:pujinet

工作时间:9:00-18:00,节假日休息

公众号

扫码关注微信公众号