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

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

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

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

程序填空题

1.使用VC++2010打开考生文件夹下blank1中的解决方案。此解决方案的项目中包含一个源程序文件blank1.c。在此程序中,函数fun的功能是:把形参s所指字符串中最右边的n个字符复制到形参t所指字符数组中,形成一个新串。若s所指字符串的长度小于n,则将整个字符串复制到形参t所指字符数组中。

例如,形参s所指的字符串为:abed吨h,n的值为5,程序执行后t所指字符数组中的字符串应为:defgh。

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

注意:部分源程序在文件BIANK1.C中。

不得增行或删行,也不得更改程序的结构!

试题程序:

#include<stdio.h>

#include<string.h>

#define N80

void fun(char*s,int n,char*t)

{int len,i,j=0;

len=strlen(s);

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

if(n>=len)strcpy(【1】);

else{

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

for(i=len-n;i<=len-1;i++)

t[j++]=【2】

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

t[j]=【3】

}

}

main()

{char s[N],t[N];int n;

printf(\\

(1)t,s

(2)s[i]

(3)0或’\0’

解析:填空1:当给定的长度n大于该字符串s的长度,那么把该字符串直接拷贝到t就可以了,所以应填t,s。

填空2:使用for循环语句,把最右边n个字符依次添加到t中,所以应填s[i]。

填空3:字符串操作结束,需要给t加一个字符串结束符,所以应填0或’\0’。

程序修改题

2.使用VC++2010打开考生文件夹下modi1中的解决方案。此解决方案的项目中包含一个源程序文件modi1.c。在此程序中,fun函数的功能是:删除b所指数组中小于10的数据。主函数中输出删除后数组中余下的数据。

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

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

试题程序:

#include<stdio.h>

#include<stdlib.h>

#define N20

int fun(int*b)

{

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

int t[N],i,num

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

if(b[i]>=10)

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

t[++num]=b[i];

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

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

b[i]=t[i];

return(FtUm);

}

main()

{int a[N],i,num;

printf(\\

(1)int t[N],i,num=0;

(2)t[num++]=b[i];或{t[num]=b[i];num++;}

(3)for(i=0;i<num;i++)

解析:要删除数组b中小于10的数,应依次取出数组数组b中的元素与10进行比较,若不小于10,则将其存入数组t中,遍历完成后,数组t中的元素即为所求,再将数组t中的元素保存到数组b中即可。

(1)元素num存放不小于10的元素的个数,应将其初始化为0。

(2)将数组b中不小于10的元素存入数组t中,同时使数组t的下标加1。

(3)语法错误,没有nun这个变量,应该为num。

程序设计题

3.使用VC++2010打开考生文件夹下prog1中的解决方案。此解决方案的项目中包含一个源程序文件prog1.c。在此程序中,已知学生的记录由学号和学习成绩构成,N名学生的数据已存入a结构体数组中。请编写函数fun,该函数的功能是:找出成绩最低的学生记录,通过形参返回主函数(规定只有一个最低分)。已给出函数的首部,请完成该函数。

注意:部分源程序在文件PROG1.C中。

请勿改动主函数main和其他函数中的任何内容,仅在函数fun的花括号中填入你编写的若干语句。

试题程序:

#include<stdio.h>

#include<string.h>

#include<conio.h>

#include<stdlib.h>

#define N10

typedef struct ss

{char num[10];

int s;

}STU;

fun(STU a[],STU*s)

{

}

void main()

{

FILE*wf;

STU a[N]={{\\

fun(STU a[],STU*s)

{

int i;

*s=a[0];/木先认为第1个值最小*/

for(i=0;i<N;i++)/*如果在循环的过程中再发现比第1个值更小的则赋给*s*/

if(s->s>a[i].s)

*s=a[i];

}

解析:找出结构体数组元素中的最小值。先认为第1个值最小,即*s=a[0];,如果在循环的过程中发现比第1个值更小的,就将指针s指向该元素,直到找到最小元素。

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

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

推荐资源

客服

扫码添加客服微信

热线

官方客服

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

电话客服:

客服微信:pujinet

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

公众号

扫码关注微信公众号