1、二级 C语言分类模拟题 261及答案解析(总分:100.00,做题时间:90 分钟)一、程序填空题(总题数:1,分数:30.00)1.给定程序中,函数 fun的功能是建立一个 NN的矩阵。矩阵元素的构成规律是:最外层元素的值全部为 1;从外向内第 2层元素的值全部为 2:第 3层元素的值全部为 3,依次类推。例如,若 N=5,生成的矩阵为: 1 1 1 1 1 1 2 2 2 1 1 2 3 2 1 1 2 2 2 1 1 1 1 1 1 请在程序的下划线处填入正确的内容并把下划线删除,使程序得出正确的结果。 注意:源程序存放在 下的 BLANK1.C中。 不得增行或删行,也不得更改程序的结构
2、! #include stdio.h #define N 7 /*found*/ void fun(int(*a)_) int i, j, k, m; if(N%2=0) m=N/2; else m=N/2+1; for(i=0; im; i+) /*found*/ for(j=_; jN-i; j+) aij=aN-i-1j=i+1; for(k=i+1; kN-i; k+) /*found*/ aki=akN-i-1=_; main() int x NN=0, i, j; fun(x); printf(“/nThe result is:/n“); for(i=0; iN; i+) for(
3、j=0; jN; j+) printf(“%3d“, xij); printf(“/n“); (分数:30.00)_二、程序修改题(总题数:1,分数:30.00)2.给定程序 MODI1.C中函数 fun的功能是:将十进制正整数 m转换成 k(2k9)进制数,并按高位到低位顺序输出。 例如,若输入 8和 2,则应输出 1000(即十进制数 8转换成二进制表示是 1000)。 请改正 fun函数中的错误,使它能得出正确的结果。 注意:不要改动 main函数。不得增行或删行,也不得更改程序的结构! #includeconio.h #includestdio.h void fun(int m, in
4、t k) int aa20, i; for(i=0; m; i+) /*found*/ aai=m/k; m/=k; for(; i; i-) /*found*/ printf(“%d“, aai); main() int b, n; printf(“/nPlease enter a number and a base:/n“); scanf(“%d %d“, fun(n, b); printf(“/n“); (分数:30.00)_三、程序设计题(总题数:1,分数:40.00)3.编写一个函数,从 num个字符串中找出最长的一个字符串,并通过形参指针 max传回该串地址。(注意:主函数中用*作
5、为结束输入的标志。) 注意:部分源程序在文件 PROG1.C中。 请勿改动主函数 main和其他函数中的任何内容,仅在函数 fun的花括号中填入你编写的若干语句。 #includestdio.h #includestring.h void fun(char(*a)81, int num, char*max) main() char ss1081, *ps; void NONO(); int n, i=0; printf(“输入若干个字符串:“); gets(ssi); puts(ssi); while(!strcmp(ssi, “*“)=0) i+; gets(ssi); puts(ssi);
6、 n=i; fun(ss, n, printf(“/nmax=%s/n“, ps); NONO(); void NONO() /*请在此函数内打开文件,输入测试数据,调用 fun函数,输出数据,关闭文件。 */ char ss2081, *ps; int n, i=0; FILE *rf, *wf; rf=fopen(“in.dat“, “r“); wf=fopen(“out.dat“, “w“); fgets(ssi, 81, rf); while(!strncmp(ssi, “*“, 4)=0) i+; fgets(ssi, 81, rf); n=i; fun(ss, n, fprintf
7、(wf, “%s“, ps); fclose(rf); fclose(wf); (分数:40.00)_二级 C语言分类模拟题 261答案解析(总分:100.00,做题时间:90 分钟)一、程序填空题(总题数:1,分数:30.00)1.给定程序中,函数 fun的功能是建立一个 NN的矩阵。矩阵元素的构成规律是:最外层元素的值全部为 1;从外向内第 2层元素的值全部为 2:第 3层元素的值全部为 3,依次类推。例如,若 N=5,生成的矩阵为: 1 1 1 1 1 1 2 2 2 1 1 2 3 2 1 1 2 2 2 1 1 1 1 1 1 请在程序的下划线处填入正确的内容并把下划线删除,使程序得
8、出正确的结果。 注意:源程序存放在 下的 BLANK1.C中。 不得增行或删行,也不得更改程序的结构! #include stdio.h #define N 7 /*found*/ void fun(int(*a)_) int i, j, k, m; if(N%2=0) m=N/2; else m=N/2+1; for(i=0; im; i+) /*found*/ for(j=_; jN-i; j+) aij=aN-i-1j=i+1; for(k=i+1; kN-i; k+) /*found*/ aki=akN-i-1=_; main() int x NN=0, i, j; fun(x); p
9、rintf(“/nThe result is:/n“); for(i=0; iN; i+) for(j=0; jN; j+) printf(“%3d“, xij); printf(“/n“); (分数:30.00)_正确答案:()解析:(1)N (2)i (3)i+1 答案考生文件夹 解析 函数 fun的功能是按照指定的规律建立一个 NN的矩阵。 第一空:第一空处是补充函数定义,在主函数内 fun的调用形式是:fun(x),x 是二维数组名,因此 fun函数的参数是一个二维数组指针,故第一空处应为“N ”。 第二空:i 等于 0时,此时第二空下的循环内 a0j=aN-1i=1,显然这是对最外围
10、的两列赋值为1;i 等于 1时,对外向内第 2列元素的值全部赋值为 2,依此类推,故第二空处 j的初值应为“i”。 第三空:“aki=akN-i-1=_; ”是对矩阵的两行进行操作,题干要求矩阵每一圈上的值都相等,故这里和上一个循环的列上的值相同,也为“i+1”。 考点 二维数组、for 循环结构二、程序修改题(总题数:1,分数:30.00)2.给定程序 MODI1.C中函数 fun的功能是:将十进制正整数 m转换成 k(2k9)进制数,并按高位到低位顺序输出。 例如,若输入 8和 2,则应输出 1000(即十进制数 8转换成二进制表示是 1000)。 请改正 fun函数中的错误,使它能得出正
11、确的结果。 注意:不要改动 main函数。不得增行或删行,也不得更改程序的结构! #includeconio.h #includestdio.h void fun(int m, int k) int aa20, i; for(i=0; m; i+) /*found*/ aai=m/k; m/=k; for(; i; i-) /*found*/ printf(“%d“, aai); main() int b, n; printf(“/nPlease enter a number and a base:/n“); scanf(“%d %d“, fun(n, b); printf(“/n“); (分
12、数:30.00)_正确答案:()解析:(1)aai=m%k; (2)printf(“%d“, aai-1); 答案考生文件夹 解析 函数的功能是将十进制正整数 m转换成 k(2k9)进制数。 (1)第二个标识下的“aai=m/k; ”是进制的转换,应该是取余,所以第二个标识下“aaim/k; ”应该改为“aai=m%k; ”。 (2)数制转换处理过程中所得的结果,和实际要输出的结果顺序是相反的,所以必须对存放余数的数组反向输出。原题中“printf(“%d“, aai); ”的下标有误。因为下标 i的起始值为 0,故反向输出时应该从 i-1开始,因此改为“printf(“%d“, aai-1)
13、; ”。 考点 一维数组、顺序程序设计。三、程序设计题(总题数:1,分数:40.00)3.编写一个函数,从 num个字符串中找出最长的一个字符串,并通过形参指针 max传回该串地址。(注意:主函数中用*作为结束输入的标志。) 注意:部分源程序在文件 PROG1.C中。 请勿改动主函数 main和其他函数中的任何内容,仅在函数 fun的花括号中填入你编写的若干语句。 #includestdio.h #includestring.h void fun(char(*a)81, int num, char*max) main() char ss1081, *ps; void NONO(); int n
14、, i=0; printf(“输入若干个字符串:“); gets(ssi); puts(ssi); while(!strcmp(ssi, “*“)=0) i+; gets(ssi); puts(ssi); n=i; fun(ss, n, printf(“/nmax=%s/n“, ps); NONO(); void NONO() /*请在此函数内打开文件,输入测试数据,调用 fun函数,输出数据,关闭文件。 */ char ss2081, *ps; int n, i=0; FILE *rf, *wf; rf=fopen(“in.dat“, “r“); wf=fopen(“out.dat“, “w
15、“); fgets(ssi, 81, rf); while(!strncmp(ssi, “*“, 4)=0) i+; fgets(ssi, 81, rf); n=i; fun(ss, n, fprintf(wf, “%s“, ps); fclose(rf); fclose(wf); (分数:40.00)_正确答案:()解析:int i, k=0, maxlen; /*k 为 a数组中最长串所在元素的下标,初始为 0,maxlen 为其串长*/ maxlen=strlen(ak); for(i=1; inum; i+) /*以下完成查找最长串*/ if(strlen(ai)maxlen) maxlen=strlen(ai); k=i; *max=ak; 答案考生文件夹 解析 该程序功能是找出最长的一个字符串。解题思路,首先指定第一个字符串为长度最大的字符串,然后在循环过程中将其与其他的所有串的长度进行比较,求出最长的串。 考点 指向一维数组的指针以及指针数组、for 循环结构。