【计算机类职业资格】二级C语言真题4及答案解析.doc

上传人:syndromehi216 文档编号:1325932 上传时间:2019-10-17 格式:DOC 页数:7 大小:36.50KB
下载 相关 举报
【计算机类职业资格】二级C语言真题4及答案解析.doc_第1页
第1页 / 共7页
【计算机类职业资格】二级C语言真题4及答案解析.doc_第2页
第2页 / 共7页
【计算机类职业资格】二级C语言真题4及答案解析.doc_第3页
第3页 / 共7页
【计算机类职业资格】二级C语言真题4及答案解析.doc_第4页
第4页 / 共7页
【计算机类职业资格】二级C语言真题4及答案解析.doc_第5页
第5页 / 共7页
点击查看更多>>
资源描述

1、二级 C 语言真题 4 及答案解析(总分:100.00,做题时间:90 分钟)一、程序填空题(总题数:1,分数:30.00)1.函数 fun 的功能是:将一副扑克牌编号为 1,2,3,53,54,以某种特定的方式洗牌,这种方式是将这副牌分成两半,然后将它们交叉,并始终保持编号为 1 的牌在最上方,如第一次这样洗牌后的结果为:1,28,2,29,53,27,54。两次洗牌后的结果为:1,41,28,15,2,42,53,40,27,14,54。 程序的功能是:输出经过 n 次这样洗牌后的结果。 请在程序的下画线处填入正确的内容,并把下画线删除,使程序得出正确的结果。 注意:源程序存放在 下的 B

2、LANK1.C 中。不得增行或删行,也不得更改程序的结构! 试题程序: 1 #includestdio.h 2 void fun(int a55,int n) 3 int i,k; 4 /*found*/ 5 int_55; 6 for(i=0“in;i+) 7 for(k=1;k=27;k+) 8 b2*k-1=ak; 9 /*found*/ 10 b_*k=ak+27; 11 12 for(k=1;k=54;k+) 13 /*found*/ 14 ak=_; 15 16 17 main() 18 int m,a55,i; 19 for(i=1;i55;i+)ai=i; printf(“请输

3、入洗牌次数:“); 20 scanf(“%d“, 21 fun(a,m); 22 for(i=1;i55;i+) printf(“%d,“,ai); 23 printf(“/n“); (分数:30.00)_二、程序修改题(总题数:1,分数:30.00)2.给定程序 MODI1.C 中,函数 fun 的功能是:判断输入的任何一个正整数 n,是否等于某个连续正整数序列之和。若是,则输出所有可能的序列,否则输出“不能分解”。 例如:当输入 100 时,输出: 100=9+10+1l+12+13+14+15+16 100=18+19+20+21+22 请改正函数 fun 中指定部位的错误,使它能得出正

4、确的结果。 注意:不要改动 main 函数,不得增行或删行,也不得更改程序的结构。 试题程序: 1 #includestdio.h 2 void fun(int n) 3 int j,b,c,m,flag=0; 4 for(b=1;b=n/2;b+) 5/*found*/ 6 n=m; 7 c=b; 8 while(m! =0c+ 11 12 /*found*/ 13 if(m!=0) 14 printf(“%d=“n); 15 for(j=b;jc-1;j+) printf(“%d+“,j); 16 printf(“%d/n“,j); 17 flag=1; 18 19 20 if(flag=

5、0) 21 printf(“不能分解/n“); 22 23 main() 24 int n; 25 printf(“请输入一个整数:“); scanf(“%d“, 26 fun(in); 27 (分数:30.00)_三、程序设计题(总题数:1,分数:40.00)3.请编写函数 fun,其功能是:判断 t 所指字符串中的字母是否由连续递增字母序列组成(字符串长度大于等于 2)。例如字符串:uvwxyz 满足要求;而字符串:uvxwyz 不满足要求。 注意:部分源程序存放在 PROG1.C 中,请勿改动主函数 main 和其他函数中的任何内容,仅在函数 fun 指定的部位填入所编写的若干语句。 试

6、题程序: 1 #includestdio.h 2 #includestring.h 3 void NONO(); 4 int fun(char *t) 5 6 7 8 main() 9 char s26; 10 printf(“请输入一个字母组成的字符串;“);gets(s); 11 if(fun(s)printf(“%s 是由连续字母组成的字符串./n“,s); 12 else printf(“%s 不是由连续字母组成的字符串!/n“,s); 13 NONO(); 14 15 void NONO() 16 /*本函数用于打开文件,输入数据,调用函数,输出数据,关闭文件。*/ 17 FILE*

7、fp,*wf; 18 int i; 19 char s26,*P; 20 fp=fopen(“c:/test/in. dat“,“r“); 21 wf=fopen(“c;/test/out. dat“.“w“); 22 for(i=0;i10;i+) 23 fgets(s,26,fp); 24 P=strchr(s,“/n“); 25 if(P)*p=0; 26 if(fun(s)fprintf(wf,“% s/n“,s+2); 27 else fprintf(wf,“%s/n“, strrev(s); 28 29 fclose(fp); 30 fclose(wf); 31 (分数:40.00

8、)_二级 C 语言真题 4 答案解析(总分:100.00,做题时间:90 分钟)一、程序填空题(总题数:1,分数:30.00)1.函数 fun 的功能是:将一副扑克牌编号为 1,2,3,53,54,以某种特定的方式洗牌,这种方式是将这副牌分成两半,然后将它们交叉,并始终保持编号为 1 的牌在最上方,如第一次这样洗牌后的结果为:1,28,2,29,53,27,54。两次洗牌后的结果为:1,41,28,15,2,42,53,40,27,14,54。 程序的功能是:输出经过 n 次这样洗牌后的结果。 请在程序的下画线处填入正确的内容,并把下画线删除,使程序得出正确的结果。 注意:源程序存放在 下的

9、BLANK1.C 中。不得增行或删行,也不得更改程序的结构! 试题程序: 1 #includestdio.h 2 void fun(int a55,int n) 3 int i,k; 4 /*found*/ 5 int_55; 6 for(i=0“in;i+) 7 for(k=1;k=27;k+) 8 b2*k-1=ak; 9 /*found*/ 10 b_*k=ak+27; 11 12 for(k=1;k=54;k+) 13 /*found*/ 14 ak=_; 15 16 17 main() 18 int m,a55,i; 19 for(i=1;i55;i+)ai=i; printf(“请

10、输入洗牌次数:“); 20 scanf(“%d“, 21 fun(a,m); 22 for(i=1;i55;i+) printf(“%d,“,ai); 23 printf(“/n“); (分数:30.00)_正确答案:()解析:b 2 bk 解析 填空 1:for 循环中使用了一个数组 b,用来临时存放交换位置后的扑克牌,C 语言中变量需要先声明后使用,所以填空(1)处需要声明一个数组 h。答案为 b。 填空 2:第二个 for 循环是将数组 a 中前一半元素(即 127 编号的扑克牌)放入数组 b 的奇数位置,将数组 a 中的后一半元素(即 2854 编号的扑克牌)放入数组 b 的偶数位置,

11、实现扑克牌的交叉洗牌。所以填空(2)处是数组 b 的起始值为 2 的偶数下标 2k,答案为 2。 填空 3:由于数组 b 属于函数中的临时变量,所以将数组 a 的元素交叉存储到数组 b 后,还需要将数组 b的元素依次赋值给数组 a,第三个 for 循环实现的功能是将数组 b 赋值给数组 a,所以填空(3)处需要填入对应下标为 k 的数组 b 的元素,答案为 bk。二、程序修改题(总题数:1,分数:30.00)2.给定程序 MODI1.C 中,函数 fun 的功能是:判断输入的任何一个正整数 n,是否等于某个连续正整数序列之和。若是,则输出所有可能的序列,否则输出“不能分解”。 例如:当输入 1

12、00 时,输出: 100=9+10+1l+12+13+14+15+16 100=18+19+20+21+22 请改正函数 fun 中指定部位的错误,使它能得出正确的结果。 注意:不要改动 main 函数,不得增行或删行,也不得更改程序的结构。 试题程序: 1 #includestdio.h 2 void fun(int n) 3 int j,b,c,m,flag=0; 4 for(b=1;b=n/2;b+) 5/*found*/ 6 n=m; 7 c=b; 8 while(m! =0c+ 11 12 /*found*/ 13 if(m!=0) 14 printf(“%d=“n); 15 for

13、(j=b;jc-1;j+) printf(“%d+“,j); 16 printf(“%d/n“,j); 17 flag=1; 18 19 20 if(flag=0) 21 printf(“不能分解/n“); 22 23 main() 24 int n; 25 printf(“请输入一个整数:“); scanf(“%d“, 26 fun(in); 27 (分数:30.00)_正确答案:()解析:m=n; (2)m=m-c;c+; (3)if(m=0) 解析 (1)每次循环,程序需要对 n 执行减去连续的正整数序列来判断 n 是否刚好为 0,即 n 是否是连续的正整数序列之和,所以需要使用临时变量

14、 m 寄存 n 的值,每次循环对 m 执行减运算操作,不满足继续下一轮。另外,程序声明变量 m 时,未初始化它的值,所以此处应该修改为:m=n。 (2)语法错误。C 语言中每个语句必须以分号结束,所以应修改为:m=m-c;c+;。 (3)题目判断 n 是否是连续的正整数序列之和,若是,则输出所有序列,程序中 m 依次减去连续的正整数,当 m 为 0 时,表示 m(即 n)满足条件,再输出当前序列中的每个正整数,所以此处判断条件反了,应修改为:if(m=0)。三、程序设计题(总题数:1,分数:40.00)3.请编写函数 fun,其功能是:判断 t 所指字符串中的字母是否由连续递增字母序列组成(字

15、符串长度大于等于 2)。例如字符串:uvwxyz 满足要求;而字符串:uvxwyz 不满足要求。 注意:部分源程序存放在 PROG1.C 中,请勿改动主函数 main 和其他函数中的任何内容,仅在函数 fun 指定的部位填入所编写的若干语句。 试题程序: 1 #includestdio.h 2 #includestring.h 3 void NONO(); 4 int fun(char *t) 5 6 7 8 main() 9 char s26; 10 printf(“请输入一个字母组成的字符串;“);gets(s); 11 if(fun(s)printf(“%s 是由连续字母组成的字符串./

16、n“,s); 12 else printf(“%s 不是由连续字母组成的字符串!/n“,s); 13 NONO(); 14 15 void NONO() 16 /*本函数用于打开文件,输入数据,调用函数,输出数据,关闭文件。*/ 17 FILE*fp,*wf; 18 int i; 19 char s26,*P; 20 fp=fopen(“c:/test/in. dat“,“r“); 21 wf=fopen(“c;/test/out. dat“.“w“); 22 for(i=0;i10;i+) 23 fgets(s,26,fp); 24 P=strchr(s,“/n“); 25 if(P)*p=

17、0; 26 if(fun(s)fprintf(wf,“% s/n“,s+2); 27 else fprintf(wf,“%s/n“, strrev(s); 28 29 fclose(fp); 30 fclose(wf); 31 (分数:40.00)_正确答案:()解析:1 int fun(char*t) 2 3 int len=strlen(t); 4 if(len2) 5 6 return 0; 7 8 char before_ch=t0; 9 char current_ch; 10 int flag=l; 11 for(int i=l;ti !=“0“;+i) 12 13 current_

18、ch=ti; 14 if(before ch!=current_ch-1) 15 16 flag=0; 17 break; 18 19 before ch=current ch; 20 21 return flag; 22 解析 函数 fun 的功能是判断指针 t 指向的字符串是否是由连续递增的字母构成,返回值为整数,0 代表不满足条件。根据题目要求,字符串长度必须大于等于 2,所以首先需要对 t 指向的字符串进行长度判断,小于2 的字符串返回 0。接着需要对字符串中的连续字符,逐个进行比较。C 语言中字符变量可以当作整数使用,所以当前字符只有是前一个字符的 ASCII 码+1,才能说它们是连续递增字母序列,然后比较后一个字符与当前字符的 ASCII 码,如果字符串中的所有字符都满足条件,则返回 1;否则说明该字符串不满足要求,此时设置 flag=0,后面的字符也就不需要再比较了,跳出循环返回即可。

展开阅读全文
相关资源
猜你喜欢
  • ASTM D7310-2011 0625 Standard Guide for Defect Detection and Rating of Plastic Films Using Optical Sensors《用光学传感器进行塑料薄膜缺陷检测和评定等级用标准指南》.pdf ASTM D7310-2011 0625 Standard Guide for Defect Detection and Rating of Plastic Films Using Optical Sensors《用光学传感器进行塑料薄膜缺陷检测和评定等级用标准指南》.pdf
  • ASTM D7311-2007 781 Standard Specification for Liquid-Applied Single-Pack Moisture-Triggered Aliphatic Polyurethane Roofing Membrane《液体用单包装湿气引起的硬化脂肪族聚氨酯屋顶薄膜的标准规范》.pdf ASTM D7311-2007 781 Standard Specification for Liquid-Applied Single-Pack Moisture-Triggered Aliphatic Polyurethane Roofing Membrane《液体用单包装湿气引起的硬化脂肪族聚氨酯屋顶薄膜的标准规范》.pdf
  • ASTM D7312-2007 Standard Test Method for Determining the Permanent Shear Strain and Complex Shear Modulus of Asphalt Mixtures Using the Superpave Shear Tester (SST)《采用超级铺面剪切试验器(SST.pdf ASTM D7312-2007 Standard Test Method for Determining the Permanent Shear Strain and Complex Shear Modulus of Asphalt Mixtures Using the Superpave Shear Tester (SST)《采用超级铺面剪切试验器(SST.pdf
  • ASTM D7312-2010 1875 Standard Test Method for Determining the Permanent Shear Strain and Complex Shear Modulus of Asphalt Mixtures Using the Superpave Shear Tester (SST)《采用超级铺面剪切试验.pdf ASTM D7312-2010 1875 Standard Test Method for Determining the Permanent Shear Strain and Complex Shear Modulus of Asphalt Mixtures Using the Superpave Shear Tester (SST)《采用超级铺面剪切试验.pdf
  • ASTM D7313-2007 Standard Test Method for Determining Fracture Energy of Asphalt-Aggregate Mixtures Using the Disk-Shaped Compact Tension Geometry《用盘状紧凑拉伸几何物测定地沥青集料混合物断裂强度的标准试验方法》.pdf ASTM D7313-2007 Standard Test Method for Determining Fracture Energy of Asphalt-Aggregate Mixtures Using the Disk-Shaped Compact Tension Geometry《用盘状紧凑拉伸几何物测定地沥青集料混合物断裂强度的标准试验方法》.pdf
  • ASTM D7313-2007a 781 Standard Test Method for Determining Fracture Energy of Asphalt-Aggregate Mixtures Using the Disk-Shaped Compact Tension Geometry《用盘状紧凑拉伸几何物测定地沥青集料混合物断裂强度的标准试验.pdf ASTM D7313-2007a 781 Standard Test Method for Determining Fracture Energy of Asphalt-Aggregate Mixtures Using the Disk-Shaped Compact Tension Geometry《用盘状紧凑拉伸几何物测定地沥青集料混合物断裂强度的标准试验.pdf
  • ASTM D7313-2013 2248 Standard Test Method for Determining Fracture Energy of Asphalt-Aggregate Mixtures Using the Disk-Shaped Compact Tension Geometry《采用盘状紧凑拉伸几何法测定地沥青集料混合物断裂强度的标准试.pdf ASTM D7313-2013 2248 Standard Test Method for Determining Fracture Energy of Asphalt-Aggregate Mixtures Using the Disk-Shaped Compact Tension Geometry《采用盘状紧凑拉伸几何法测定地沥青集料混合物断裂强度的标准试.pdf
  • ASTM D7314-2008 317 Standard Practice for Determination of the Heating Value of Gaseous Fuels using Calorimetry and On-line At-line Sampling.pdf ASTM D7314-2008 317 Standard Practice for Determination of the Heating Value of Gaseous Fuels using Calorimetry and On-line At-line Sampling.pdf
  • ASTM D7314-2010 8750 Standard Practice for Determination of the Heating Value of Gaseous Fuels using Calorimetry and On-line At-line Sampling《用测热法和在线自动采样法测定气体燃料热值的标准实施规程》.pdf ASTM D7314-2010 8750 Standard Practice for Determination of the Heating Value of Gaseous Fuels using Calorimetry and On-line At-line Sampling《用测热法和在线自动采样法测定气体燃料热值的标准实施规程》.pdf
  • 相关搜索
    资源标签

    当前位置:首页 > 考试资料 > 职业资格

    copyright@ 2008-2019 麦多课文库(www.mydoc123.com)网站版权所有
    备案/许可证编号:苏ICP备17064731号-1