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

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

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

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

程序填空题

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次这样洗牌后的

结果。

请在程序的下画线处填入正确的内容,并把下画线删除,使程序得出正确的结果。

注意:源程序存放在考生文件夹下的BLANK1.C中。不得增行或删行,也不得更改程序的结构!

试题程序:

#iclucle<Stdio.h>

void fun(int a[55],int n)

{ int i,k;

/*********found*********/

int 【1】[55];

for(i=0;i<n;i++)

{ for(k=1;k<=27;k++)

{b[2*k一1]=a[k];

/*********found*********/

b[【2】*k]=a[k+27];

}

for(k=1 ; k<=54;k++)

/*********found*********/

a[k]=【3】

}

}

main()

{ int m,a[55],i;

for(i=1;i<55;i++)a[i]=i;

printf(\\

(1)b

(2)2

(3)b[k]

解析:填空1:for循环中使用了一个数组b,用来临时存放交换位置后的扑克牌,c语言中变量需要先声明后使用,所以填空(1)处需要声明一个数组b。答案为b。

填空2:第二个for循环是将数组a中前一半元素(即1~27编号的扑克牌)放入数组b的奇数位置,将数组a中的后一半元素(即28~54编号的扑克牌)放入数组b的偶数位置,实现扑克牌的交叉洗牌。所以填空(2)处是数组b的起始值为2的偶数下标2k,答案为2。

填空3:由于数组b属于函数中的临时变量,所以将数组a的元素交叉存储到数组b后,还需要将数组b的元素依次赋值给数组a,第三个for循环实现的功能是将数组b赋值给数组a,所以填空(3)处需要填入对应下标为k的数组b的元素,答案为b[k]。

程序修改题

2.给定程序NODI1.C中,函数fun的功能是:判断输入的任何一个正整数n,是否等于某个连续正整数序列之和。若是,则输出所有可能的序列,否则输出“不能分解”。

例如:当输入100时,输出:

100=9+10+11+12+13+14+15+16

100=18+19+20+21+22

请改正函数fun中指定部位的错误,使它能得出正确的结果。

注意:不要改动main函数,不得增行或删行,也不得更改程序的结构。

试题程序:

#include<stdio.h>

void fun(int n)

{ int j,b,c,m,flag=0;

for(b=1;b<=n/2;b++){

/*********found*********/

n=m;

c=b;

while(m!=0&&m>=c){

/*********found*********/

m=m—c;c++

}

/*********found*********/

if(m!=0)

{printf(\\

(1)m=n;

(2)m=m—c;c++;

(3)if(m==0)

解析:(1)每次循环,程序需要对n执行减去连续的正整数序列来判断n是否刚好为0,即n是否是连续的正整数序列之和,所以需要使用临时变量m寄存n的值,每次循环对m执行减运算操作,不满足继续下一轮。另外,程序声明变量m时,未初始化它的值,所以此处应该修改为:m=n。

(2)语法错误。C语言中每个语句必须以分号结束,所以应修改为:m=m—c;c++;。

(3)题目判断n是否是连续的正整数序列之和,若是,则输出所有序列,程序中m依次减去连续的正整数,当m为0时,表示m(即n)满足条件,再输出当前序列中的每个正整数,所以此处判断条件反了,应修改为:if(m==0)。

程序设计题

3.请编写函数fun,其功能是:判断t所指字符串中的字母是否由连续递增字母序列组成 (字符串长度大于等于2)。例如字符串:uvwxyz满足要求;而字符串:uvxwyz不满足要求。

注意:部分源程序存放在PROGI.C中,请勿改动主函数main和其他函数中的任何内容,仅在函数fun指定的部位填入所编写的若干语句。

试题程序:

#include<stdio.h>

#include<string.h>

void NONO();

int fun(char*t)

{

}

main()

{ char s[26];

printf(\\

int fun(char*t)

{

int len=strlen(t);

if(len <2)

{

return 0;

}

char before_ch=t[0],

char current_ch;

int flag=1;

for (int i=1;t[i] !=’\0’; ++i)

{

current_ch=t[i];

if(before_ch!=cur rent_ch一1)

{

flag=0;

break;

}

before_ch=current_ch;

}

return flag;

}

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

本文档预览:3600字符,共3304字符,源文件无水印,下载后包含无答案版和有答案版,查看完整word版点下载

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

推荐资源

客服

扫码添加客服微信

热线

官方客服

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

电话客服:

客服微信:pujinet

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

公众号

扫码关注微信公众号