1、二级 C 语言-204 (1)及答案解析(总分:100.00,做题时间:90 分钟)一、程序填空题(总题数:1,分数:30.00)1.请补充函数 proc(char*str),该函数的功能是把字符串中的内容逆置。 例如,字符串中原有的字符串为 abcdefg,则调用该函数后,串中的内容变为 gfedcba。 注意:部分源程序给出如下。 请勿改动 main()函数和其他函数中的任何内容,仅在函数 proc()的横线上填入所编写的若干表达式或语句。 试题程序: #includestdlib.h #includestring.h #includeconio.h #includestdio.h #de
2、fine M 81 void proc(char*str) int i=0,t,n=strlen(str); for(; 1;i+) t=*(str+i); 2; 3; void main() char strM; system(“CLS“); printf(“Enter a string:“); gets(str); printf(“The original string is:“); puts(str); proc(str); printf(“/n“); printf(“The string after modified:“); puts(str); (分数:30.00)二、程序改错题(总
3、题数:1,分数:30.00)2.下列给定程序中,函数 proc()的功能是:将字符串 str 中的所有字符复制到字符串 b 中,要求在每复制 3 个字符之后插入 1 个空格。例如,在调用 proc()函数之前给字符串 str 输入 abcdefghijk,调用函数之后,字符串 b 中的内容则为 abc def ghijk。 请修改程序中的错误,使它能得出正确的结果。 注意:不要改动 main()函数,不得增行或删行,也不得更改程序的结构。 试题程序: #includestdio.h void proc(char*str,char*b) int i,k=0; while(*str) /*foun
4、d* i=1; /*found* while(i3|*str) bk=*str; k+;str+;i+; if(*str) /*found* bk=“; bk=“/0“; void main() char str80,b80; printf(“Enter a string:“);gets(str); printf(“The original string:“); puts(str); proc(str,b); printf(“/nThe string after insert space:“);puts(b);printf(“/n/n“); (分数:30.00)三、程序设计题(总题数:1,分数
5、:40.00)3.请编写函数 proc(),该函数的功能是:移动一维数组中的内容,若数组中有 n 个整数,要求把下标从p 到 n-1(pn-1)的数组元素平移到数组的前面。 例如,一维数组中的原始内容为 1,2,3,4,5,6,7,8,9,10,11,12,13,14,p 的值为 4。移动后,一维数组中的内容应为 5,6,7,8,9,10,11,12,13,14,1,2,3,4。 注意:部分源程序给出如下。 请勿改动 main()函数和其他函数中的任何内容,仅在函数 proc()的花括号中填入所编写的若干语句。 试题程序: #includestdio.h #define M 80 void p
6、roc(int*w,int p,int n) void main() int arrM=1,2,3,4,5,6,7,8,9,10,11,12,13,14; int i,p,n=14; printf(“The original data:/n“); for(i=0;in;i+) printf(“%3d“,arri); printf(“/n/nEnter p:“); scanf(“%d“, proc(arr,p,n); printf(“/nThe data after moving:/n“); for(i=0;in;i+) printf(“%3d“,arri); printf(“/n/n“); (
7、分数:40.00)_二级 C 语言-204 (1)答案解析(总分:100.00,做题时间:90 分钟)一、程序填空题(总题数:1,分数:30.00)1.请补充函数 proc(char*str),该函数的功能是把字符串中的内容逆置。 例如,字符串中原有的字符串为 abcdefg,则调用该函数后,串中的内容变为 gfedcba。 注意:部分源程序给出如下。 请勿改动 main()函数和其他函数中的任何内容,仅在函数 proc()的横线上填入所编写的若干表达式或语句。 试题程序: #includestdlib.h #includestring.h #includeconio.h #includest
8、dio.h #define M 81 void proc(char*str) int i=0,t,n=strlen(str); for(; 1;i+) t=*(str+i); 2; 3; void main() char strM; system(“CLS“); printf(“Enter a string:“); gets(str); printf(“The original string is:“); puts(str); proc(str); printf(“/n“); printf(“The string after modified:“); puts(str); (分数:30.00)
9、解析:in/2 *(str+i)=*(str+n-1-i) *(str+n-1-i)=t解析 要将字符串中的内容逆置,可以通过将字符串中的第一个字符和最后一个字符互换,第二个和倒数第二个互换,直到字符串 str 最中间的字符为止,因此,第一处填“in/2”。for 循环体中的语句功能为将第 i 个字符与第(n-1-i)个字符互换,因此,第二处填“*(str+i)=*(str+n-1-i)”;第三处填“*(str+n-1-i)=t”。二、程序改错题(总题数:1,分数:30.00)2.下列给定程序中,函数 proc()的功能是:将字符串 str 中的所有字符复制到字符串 b 中,要求在每复制 3
10、个字符之后插入 1 个空格。例如,在调用 proc()函数之前给字符串 str 输入 abcdefghijk,调用函数之后,字符串 b 中的内容则为 abc def ghijk。 请修改程序中的错误,使它能得出正确的结果。 注意:不要改动 main()函数,不得增行或删行,也不得更改程序的结构。 试题程序: #includestdio.h void proc(char*str,char*b) int i,k=0; while(*str) /*found* i=1; /*found* while(i3|*str) bk=*str; k+;str+;i+; if(*str) /*found* bk
11、=“; bk=“/0“; void main() char str80,b80; printf(“Enter a string:“);gets(str); printf(“The original string:“); puts(str); proc(str,b); printf(“/nThe string after insert space:“);puts(b);printf(“/n/n“); (分数:30.00)解析:错误:i=1; 正确:i=0; 错误:while(i3|*str) 正确:while(i3 正确:bk+=“; 解析 由函数 proc()可知,变量 i 为计算每次字符个数
12、是否到 3 的计数器变量,其初始值为 0,因此,i=1;应改为 i=0;。当计数器 i 小于 3,而且字符串 str 没有结束时,将 str 中的字符赋值给字符串 b,因此,“while(i3|*str)”应改为“while(i3”应改为“bk+=“;”。三、程序设计题(总题数:1,分数:40.00)3.请编写函数 proc(),该函数的功能是:移动一维数组中的内容,若数组中有 n 个整数,要求把下标从p 到 n-1(pn-1)的数组元素平移到数组的前面。 例如,一维数组中的原始内容为 1,2,3,4,5,6,7,8,9,10,11,12,13,14,p 的值为 4。移动后,一维数组中的内容应
13、为 5,6,7,8,9,10,11,12,13,14,1,2,3,4。 注意:部分源程序给出如下。 请勿改动 main()函数和其他函数中的任何内容,仅在函数 proc()的花括号中填入所编写的若干语句。 试题程序: #includestdio.h #define M 80 void proc(int*w,int p,int n) void main() int arrM=1,2,3,4,5,6,7,8,9,10,11,12,13,14; int i,p,n=14; printf(“The original data:/n“); for(i=0;in;i+) printf(“%3d“,arri
14、); printf(“/n/nEnter p:“); scanf(“%d“, proc(arr,p,n); printf(“/nThe data after moving:/n“); for(i=0;in;i+) printf(“%3d“,arri); printf(“/n/n“); (分数:40.00)_正确答案:()解析:void proc(int*w,int p,int n) int i,j,t; for(i=p;i=n-1;i+) t=wn-1;/t 放最后一个元素 for(j=n-2;j=0;j-) wj+1=wj; /每循环一次,把所有的元素往后移 w0=t; /再把最后一个放到第一个空间中 解析 题目中要求把下标从 p 到 n-1 的数组元素平移到数组的前面,可以通过每一次循环将最后一个元素放在第一个位置上,使其成为第一个元素,其余元素后移一个位置。通过 n-1-p 次循环实现将从 p到 n-1 的数组元素平移到数组的前面。
copyright@ 2008-2019 麦多课文库(www.mydoc123.com)网站版权所有
备案/许可证编号:苏ICP备17064731号-1