1、国家二级 C语言机试(操作题)模拟试卷 272及答案解析(总分:6.00,做题时间:90 分钟)一、程序填空题(总题数:1,分数:2.00)1.给定程序中,函数 fun的功能是:判定形参 a所指的 NN(规定 N为奇数)的矩阵是否是“幻方“,若是,函数返回值为 1;若不是,函数返回值为 0。“幻方“的判定条件是:矩阵每行、每列、主对角线及反对角线上元素之和都相等。 例如,以下 33的矩阵就是一个“幻方“: 4 9 2 3 5 7 8 1 6 请在程序的下画线处填入正确的内容并把下画线删除,使程序得出正确的结果。 注意:部分源程序在文件 BIANK1C 中。不得增行或删行,也不得更改程序的结构!
2、 试题程序: 1 #includeStdioh 2 #define N 3 3 int fun(int(*a)N) 4 int i,j,m1,m2,row,colum; 5 m1=m2=0; 6 for(i=0;iN;i+) 7 j=Ni1;m1+=aii; 8 m2+=aij; 9 if(m1!=m2)return 0; 10 for(i=0;iN;i+) 11 *found* 12 row=colum= 【1】 ; 13 for(j=0;jN;j+) 14 row+=aij; 15 colum+=aji;) 16 *found* 17 if(row!=colum) 【2】 (row!=m1
3、) 18 return 0 ; 19 20 *found* 21 return 【3】 ; 22 23 main() 24 int xNN,i,j; 25 printf(“Enter number for array:n“); 26 for(i=0;iN ;i+) 27 for(j=0;jN;j+) 28 scanf(“d“,xij); 29 printf(“Array:n“); 30 for(i=0;iN;i+) 31 for(j=0;jN;j+) 32 printf(“3d“,xij); 33 printf(“n“); 34 35 if(fun(x) 36 printf(“The Arra
4、y is amagic squaren“); 37 else 38 printf(“The Array isnta magic squaren“); 39 (分数:2.00)_二、程序修改题(总题数:1,分数:2.00)2.下列给定程序中函数 fun的功能是:用冒泡法对 6个字符串按由小到大的顺序进行排序。请改正程序中的错误,使它能得出正确的结果。注意:不要改动 main函数,不得增行或删行,也不得更改程序的结构!试题程序:#includestdlibh#includestringh#includeconioh#includestdioh#define MAXLINE 20fun(char*p
5、str6) int i,j; char*P; for(i=0;i5;i+) *found* for(j=i+1,j6,j+) if(strcrnp(*(pstr+i),(pstr+j)0) P=*(pstr+i); *found* *(pstr+i)=pstr+j; *(pstr+j)=p; void main() int i; char*pstr6,str6MAxLINE; system(“CLS“); for(i=0;i6;i+) pstri=stri;printf(“nEnter 6 string(1 string at each line):n“); for(i=0;i6;i+) sc
6、anf(“s“,pstri); fun(pstr); printf(“The strings after sorting:n“); for(i=0;i6;i+) printf(“sn“,pstr i); (分数:2.00)_三、程序设计题(总题数:1,分数:2.00)3.请编写函数 fun,其功能县将形参 s所指字符串放入形参 a所指的字符数组中,使 a中存放同样的字符串。说明:不得使用系统提供的字符串函数。注意:部分源程序存在 PROG1C 中,请勿改动主函数 main和其他函数中的任何内容,仅在函数 fun指定的部位填入所编写的若干语句。试题程序:#includestdioh#defiti
7、e N 20void NONO();void fun(char*a,char*s)main()char s1N,*s2=“abcdefghijk“; fun(s1,s2); printf(“S、n“,s1); printf(“Sn“,s2); NONO(),void NONO()*本函数用于打开文件,输入数据,调用函数,输出数据,关闭文件。* FILE*fp,*wf; int i ; char s1256,s2256; fp=fopen(“indat“,“r“), wf=fopen(“outdat“,“W“); for(i=0;i10;i+) fgets(s2,255,fp); fun(s1,
8、s2); fprintf(wf,“s“,s1); fclose(fp); fclose(wf);(分数:2.00)_国家二级 C语言机试(操作题)模拟试卷 272答案解析(总分:6.00,做题时间:90 分钟)一、程序填空题(总题数:1,分数:2.00)1.给定程序中,函数 fun的功能是:判定形参 a所指的 NN(规定 N为奇数)的矩阵是否是“幻方“,若是,函数返回值为 1;若不是,函数返回值为 0。“幻方“的判定条件是:矩阵每行、每列、主对角线及反对角线上元素之和都相等。 例如,以下 33的矩阵就是一个“幻方“: 4 9 2 3 5 7 8 1 6 请在程序的下画线处填入正确的内容并把下画
9、线删除,使程序得出正确的结果。 注意:部分源程序在文件 BIANK1C 中。不得增行或删行,也不得更改程序的结构! 试题程序: 1 #includeStdioh 2 #define N 3 3 int fun(int(*a)N) 4 int i,j,m1,m2,row,colum; 5 m1=m2=0; 6 for(i=0;iN;i+) 7 j=Ni1;m1+=aii; 8 m2+=aij; 9 if(m1!=m2)return 0; 10 for(i=0;iN;i+) 11 *found* 12 row=colum= 【1】 ; 13 for(j=0;jN;j+) 14 row+=aij;
10、15 colum+=aji;) 16 *found* 17 if(row!=colum) 【2】 (row!=m1) 18 return 0 ; 19 20 *found* 21 return 【3】 ; 22 23 main() 24 int xNN,i,j; 25 printf(“Enter number for array:n“); 26 for(i=0;iN ;i+) 27 for(j=0;jN;j+) 28 scanf(“d“,xij); 29 printf(“Array:n“); 30 for(i=0;iN;i+) 31 for(j=0;jN;j+) 32 printf(“3d“,
11、xij); 33 printf(“n“); 34 35 if(fun(x) 36 printf(“The Array is amagic squaren“); 37 else 38 printf(“The Array isnta magic squaren“); 39 (分数:2.00)_正确答案:(正确答案:(1)0 (2) (3)1)解析:解析:填空 1:本题考查为变量赋初值,在这里 row+=aij代表是每行的总和,colum+=aji代表的是每列的总和,因而 row,colum 在初始化时应该为零,此空应该填 0。 填空 2:本题考查了 if条件语句,此句 if判断代表每行的总和与列是
12、否相等,每行的总和是否与对角线的总和相等,两者若有一个不成立,即返回 0,因而此空应该填写。 填空 3:题目要求若矩阵是“幻方”,则函数返回值为 1,因而此空应该填写 1。二、程序修改题(总题数:1,分数:2.00)2.下列给定程序中函数 fun的功能是:用冒泡法对 6个字符串按由小到大的顺序进行排序。请改正程序中的错误,使它能得出正确的结果。注意:不要改动 main函数,不得增行或删行,也不得更改程序的结构!试题程序:#includestdlibh#includestringh#includeconioh#includestdioh#define MAXLINE 20fun(char*pst
13、r6) int i,j; char*P; for(i=0;i5;i+) *found* for(j=i+1,j6,j+) if(strcrnp(*(pstr+i),(pstr+j)0) P=*(pstr+i); *found* *(pstr+i)=pstr+j; *(pstr+j)=p; void main() int i; char*pstr6,str6MAxLINE; system(“CLS“); for(i=0;i6;i+) pstri=stri;printf(“nEnter 6 string(1 string at each line):n“); for(i=0;i6;i+) scan
14、f(“s“,pstri); fun(pstr); printf(“The strings after sorting:n“); for(i=0;i6;i+) printf(“sn“,pstr i); (分数:2.00)_正确答案:(正确答案:(1)for(j=i+l;j6;j+) (2)*(pstr+i)=*(pstr+j);)解析:解析:本题考查:冒泡排序算法;for 循环语句格式;指针数组。 (1)此处考查 for语句的格式,各表达式之间应用“;”隔开。 (2)此处考查用指针表示数组元素的方法,*(pstr+i)表示 pstr所指向数组的第 i个元素,同理*(pstr+j)表示 pstr所
15、指向数组的第 j个元素。 冒泡排序算法,其基本思想是:将待排序的元素看做是竖着排列的“气泡”,较小的元素比较轻,从而要往上浮。在冒泡排序算法中要对“气泡”序列处理若干遍。所谓一遍处理,就是自底向上检查一遍这个序列,并时刻注意两个相邻元素的顺序是否正确。如果发现两个相邻元素的顺序不对,即“轻”的元素在下面,就交换它们的位置。显然,处理一遍之后,“最轻”的元素就浮到了最高位置;处理两遍之后,“次轻”的元素就浮到了次高位置。依此类推,完成排序。 实现数组 sN的升序排列代码如下: for(i=0;iN;i+) for(j=i+1;jN;j+) if(sisj) t=si;si=sj; sj=t;)三
16、、程序设计题(总题数:1,分数:2.00)3.请编写函数 fun,其功能县将形参 s所指字符串放入形参 a所指的字符数组中,使 a中存放同样的字符串。说明:不得使用系统提供的字符串函数。注意:部分源程序存在 PROG1C 中,请勿改动主函数 main和其他函数中的任何内容,仅在函数 fun指定的部位填入所编写的若干语句。试题程序:#includestdioh#defitie N 20void NONO();void fun(char*a,char*s)main()char s1N,*s2=“abcdefghijk“; fun(s1,s2); printf(“S、n“,s1); printf(“
17、Sn“,s2); NONO(),void NONO()*本函数用于打开文件,输入数据,调用函数,输出数据,关闭文件。* FILE*fp,*wf; int i ; char s1256,s2256; fp=fopen(“indat“,“r“), wf=fopen(“outdat“,“W“); for(i=0;i10;i+) fgets(s2,255,fp); fun(s1,s2); fprintf(wf,“s“,s1); fclose(fp); fclose(wf);(分数:2.00)_正确答案:(正确答案:void fun(char*a,char*s) while(*s!=0) *a=*s; a+; s+; *a=0; )解析:解析:要将 s所指的字符串存入 a所指的字符串中,程序要求不能使用系统提供的字符串函数,本题可以使用循环语句,依次取出 a所指字符串中的元素,将其存入 s所指的字符串中,最后为 s所指的字符串添加结束标识0。