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

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

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

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

程序填空题

1.使用VC++2010打开考生文件夹下blank1中的解决方案。此解决方案的项目中包含一个源程序文件blank1.c。在此程序中,函数fun的功能是:找出N×N矩阵中每列元素中的最大值,并按顺序依次存放于形参b所指的一维数组中。

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

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

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

试题程序:

#inclucle<stdl0.h>

#define N 4

void fun(int(*a)[N],int *b)

{ int i,j;

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

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

b[i]=【1】;

for (j=1;j<N;j++)

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

if(b[i]【2】a[j][i])

b[i]=a[j][i];

}

}

main()

{int x[N][N]=f{12,5,8,7},{6,1,9,3},{1,2,3,4},{2,8,4,3}},y[N],i,j;

print:f(\\

(1)a[0][i](2)<(3)x,y

解析:填空1:数组b用于存放每列元素中的最大值,首先将第i列的第一个数赋给b[i],然后用b[i]与其他数进行比较,因此此空应填a[0][i]。

填空2:if条件表达式表示当b[i]小于a[j][i]时,就把a[j][i]的值赋给b[i],因此此空应该填<。

填空3:fun函数的调用,通过fun(int(*a)[N],int*b)可知,此空应该填x,y。

程序修改题

2.使用VC++2010打开考生文件夹下modil中的解决方案。此解决方案的项目中包含一个源程序文件modil.c。在此程序中,函数fun的功能是:将主函数中两个变量的值进行交换。例如,若变量a中的值为8,b中的值为3,则程序运行后,a中的值为3,b中的值为8。

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

注意:部分源程序在文件NODI1.C中,不要改动main函数。不得增行或删行,也不得更改程序的结构!

试题程序:

#include<stdio.h>

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

void fun(int x,int y)

{int t,

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

t=x;x=y;y=t;

}

void main()

{int a,b;

a=8;

b=3;

fun(&a,&b);

printf(\\

(1)void fun(int *x,int *y)

(2)t=*x;*x=*y;*y=t;

解析:(1)本题考查指针变量作函数参数。一般变量作参数时,不能改变实参的值,采用指针变量作为参数则能够改变实参的值。主函数中fun函数的调用方式表明fun函数的参数应当为指针类型。

(2)此处是一个变量交换操作错误,可知x、y是指针类型,变量类型不同,因而x、y不能与t进行值的交换。

程序设计题

3.使用VC++2010打开考生文件夹下prog1中的解决方案。此解决方案的项目中包含一个源程序文件prog1.c。在此程序中,编写函数intfun(int lim,int aa[MAX]),其功能是求出小于或等于lim的所有素数并放在aa数组中,并返回所求出的素数的个数。

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

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

试题程序:

#include<conio.h>

#include<stdio.h>

#include<stdlib.h>

#define NAX 100

int fun(int lim,int aa[NAX])

{

}

voidmain()

{

FTLE * wf;

int limit,i,sum;

int aa[MAx];

system(\\

int fun(int lim,int aa[MAX])

{

int i,j,k=0;

for(i=2;i<=lim;i++)/*求出小于或等于lim的全部素数*/

{for(j=2;j<i;j++)

if(i%j==0)break;

if(j>=i)

aa[k++]=i,/*将求出的素数放入数组aa中*/

}

return k;/*返回所求出的素数的个数*/

}

解析:本程序如果一个数是合数,那么它的最小质因数肯定小于等于他的平方根。使用for循环语句查找小于lim的所有数,使用内嵌的循环判断语句判断该数是否为素数。在做这道题时,需要重点掌握素数的判定方法:

for(j=2;j<sqrt(i);j++)

if(i%j==0)break;

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

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

推荐资源

客服

扫码添加客服微信

热线

官方客服

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

电话客服:

客服微信:pujinet

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

公众号

扫码关注微信公众号