首页 > 全部 > 二级C语言 > 国家二级(C语言)机试模拟试卷1020

国家二级(C语言)机试模拟试卷1020

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

国家二级(C语言)机试模拟试卷1020

程序填空题

1.使用VC++2010打开考生文件夹下blankl中的解决方案。此解决方案的项目中包含一个源程序文件blankl.c。在此程序中,人员的记录由编号和出生年、月、日组成,N名人员的记录已在主函数存人结构体数组std中。函数fun()的功能是找出指定出生年份的人员,将其记录放在形参k所指的数组中,由主函数输出,同时由函数值返回满足指定条件的人数。

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

注意:部分源程序给出如下。

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

试题程序:

#include <stdio.h>

#define N 8

typedef struct

{ int num;

int year,month,day;

}STU;

int fun(STU *std,STU *k,jnt year)

{ int i,n=0;

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

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

if(【1】==year)

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

k[n++]=【2】

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

return(【3】);

}

main()

{ STU std[N]=({1,1984,2,15},{2,1983,9,21),{3,1984,9,1},{4,1983,7,15},{5,1985,9,28},{6,1982,11,15},{7,1982,6,22},{8,1984,8,19}};

STU k[N];int i,n,year;

printf(\\

(1)std[i].year (2)std[i] (3)n

解析:本题要求从给定的人员数据中找出与指定出生年份相同的记录,并存入变量k中,返回符合条件的人数。

填空1:此空判断结构体变量中的年份与变量year是否相等,故空1处应该填std[i].year。

填空2:把符合条件的记录std[i]依次存入数组k中,故空2处应该填std[i]。

填空3:函数返回满足条件的人数,数组k的元素下标n,每存储完一个数据后自增1,故空3处应该填n。

程序修改题

2.使用VC++2010打开考生文件夹下modil中的解决方案。此解决方案的项目中包含一个源程序文件modil.c。程序的功能是读入一个整数k(2≤k≤10000),输出它的所有质因子(所有为素数的因子)。例如,若输入整数2310,则应输出2,3,5,7,11。

请改正程序中的错误,使它能得出正确的结果。

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

试题程序:

#include <conio.h>

#include <stdio.h>

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

int IsPrime(int n);

{

int i,m;

m=1;

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

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

if!(n%i)

{m=0;break;}

return(m);

}

main()

{

int j,k;

printf(\\

(1)IsPrime(int n) (2)if(!(n%i))

解析:(1)函数定义格式错误,函数定义时后面不能加“;”,所以应该去掉分号。

(2)根据题意可知,if条件语句判断i是否可以整除n,如果不能整除则为质因子,所以if!(n%i)应改为if(!(n%i))。

程序设计题

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

注意:部分源程序给出如下。

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

试题程序:

#include <stdlib.h>

#include <stdio.h>

#include <string.h>

#include <conio.h>

#define N 10

typedef struct ss/*定义结构体*/

{ char num[10];

int s;

}STU;

fun(STU a[],STU *s)

{

}

void main()

{

STU a[N]={{\\

fun(STU a[],STU s)

{

int i;

*s=a[0];

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

/*找出成绩最高的学生记录*/

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

*s=a[i];

}

解析:先使指针变量s指向第1名学生。通过循环语句遍历所有学生的成绩,利用条件语句判断当前学生成绩是否最高。所以if条件表达式为s->s<a[i].s。此外,做题时应该熟练掌握“指向运算符”和“成员运算符”的相关知识,题中“s->s”等价于“(*s).s”。

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

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

推荐资源

客服

扫码添加客服微信

热线

官方客服

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

电话客服:

客服微信:pujinet

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

公众号

扫码关注微信公众号