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

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

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

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

程序填空题

1.给定程序中,函数fun的功能是:有NxN矩阵,根据给定的m(m<=N)值,将每行元素中的值均右移m个位置,左边置为0。

例如,N=3,m=2,有下列矩阵

1 2 3

4 5 6

7 8 9

程序执行结果为

0 0 1

0 0 4

0 0 7

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

注意:源程序存放在考生文件夹下的BLANK1.C中。

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

#include

#define N 4

void fun (int (*t) [N], int m)

{ int i,j;

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

{ for(j=N—l—m; j>=0; j——)

for(j=0; j<____3____; j++)

t[i][j]=0;

}

}

main ()

{ int t[] [N]={21,12,13,24,25,16,

47,38,29,11,32,54 f 42,21,33,10 }, i,i,m;

printf (\\

(1)i++

(2)m

(3)m

解析:函数fun的功能是将每行元素中的值均右移m个位置。

第一空:题目要求对每行元素中的值均右移m个位置,故第一空处循环变量每次增l,共循环N次,完成对N行的移位操作,因此第一空处应为“i++”。

第二空:循环“for(j=N—l—m; j>=0; j——)”是进行行元素中的值右移m个位置,即把t[i][j]元素放置在t[i][j+m]上,因此第二空应为“m”。

第三空:循环“for(j=0; j<____3____;j++)”是对空出来的位置补0,每行元素的前m位数据已经移动到后面,每行空处m个元素,因此第三空为“m”。

程序修改题

2.给定程序MODI1.C中函数fun的功能是:计算并输出high以内最大的10个素数之和。high的值由主函数传给fun函数。

若high的值为:100,则函数的值为:732。

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

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

#include

#include

int fun (int high)

{ int sum =0,n=0,j,yes;

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

while ((high >= 2) && (n < 10)

{ yes = 1;

for (j=2; j<=high/2; j++)

if (high % j ==0) {

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

yes=0; break

}

if (yes) {sum +=high; n++;

high——;

}

return sum ;

}

main ()

{

printf (\\

(1) while( (2<=high)&&(n<10))

(2) yes=0; break;

解析:函数的功能是计算并输出high以内最大的10个素数之和。

(1)C语言中左右括弧必须成对出现,在第一个标识下“while((high>=2)&&(n<10)”中,显然缺少一个右括弧,应改为“while((2<=high)&&(n<10))”。

(2)在判断素数的循环过程中,只要被判断的数能被某数整除就不是素数,就会跳出判断循环,在C语言中使用break语句跳出循环,并且C语言中的语句使用分号为结尾。所以“break”应改为“break; ”。

程序设计题

3.编写函数fun,它的功能是:利用以下所示的简单迭代方法求方程:cos(x)—x=0的一个实根。

Xn=1=cos(Xn)

迭代步骤如下:

(1)取x1初值为0.0;

(2) x0 =x1,把x1的值赋给x0;

(3) x1=cos(x0),求出一个新的x1;

(4)若x0 — x1的绝对值小于0.000001,执行步骤(5),否则执行步骤(2);

(5)所求x1就是方程cos(x)—x=0的一个实根,作为函

数值返回。

程序将输出结果RooF0.739086。

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

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

#include

#include

double fun()

{

}

main()

{

void NONO ();

printf (\\

1 float x0, xl=0,0;

2 do {

3 x0=x1;

4 xl=cos (x0)j

5 } while (fabs (x0—x1)0.000001);

6 return x1;

解析:该程序功能是利用简单迭代方法求方程的一个实根。牛顿迭代法的求解思想是从一个初始值开始,逐步逼近所求方程的根。

其具体过程是:将初始值代入迭代公式,得到一个迭代输出值。再次迭代时,将上一次的迭代输出值当作本次的迭代输入。不断重复以上过程,直到满足题目要求为止。

牛顿迭代公式为:Xn+I=Xn—f(x)/f (x)。

其求解过程在题干中已经给出。

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

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

推荐资源

客服

扫码添加客服微信

热线

官方客服

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

电话客服:

客服微信:pujinet

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

公众号

扫码关注微信公众号