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

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

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

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

程序填空题

1.给定程序中,函数fun的功能是:在3×4的矩阵中找出在行上最大、在列上最小的那个元素,若没有符合条件的元素则输出相应信息。

例如,有下列矩阵:

1 2 13 4

7 8 10 6

3 5 9 7

程序执行结果为:find:a[2][2]=9

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

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

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

试题程序:

#include<stdio.h>

#define N 3

#define N 4

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

{int i=0,j,find=0,rmax,c,k;

while((i<M)&&(!find))

{Emax=a[i][0]; c=0;

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

if(Emax<a[i][j]){

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

rmax=a[i][j];c=【1】

find=1;k=0;

while(k<M&&find){

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

if(k!=i&&a[k][c]<=Emax)

find=【2】

k++;

}

if(find)

printf(\\

(1)j

(2)0

(3)i++

解析:本题是在矩阵中找出在行上最大、在列上最小的那个元素。

填空1:找出行上最大的数,并将该数的列数j保存在c中,所以应填j。

填空2:使用while循环语句和控制变量find,如果该数不是列中的最小数,那么把find置0,所以应填0。

填空3:i是while的控制变量,所以每做一次循环,该数值要加1,所以应填i++。

程序修改题

2.在主函数中从键盘输入若干个数放入数组中,用0结束输入并放在最后一个元素中。下列给定程序中,函数fun的功能是:计算数组元素中所有值为正数的平均值(不包括0)。

例如,数组中元素的值依次为:39、一47、21、2、一8、15、0,则程序的运行结果为19.250000。

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

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

试题程序:

#include<conio.h>

#include<stdio.h>

double fun(int x[])

{

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

int slim=0.0;

int c=0,i=0;

while(x[i]!=0)

{

if(x[i]>0)

{

sum+=x[i];

c++;

}

i++;

}

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

sum\=c;

return sum;

}

main()

{

int x[1000];

int i=0;

printf(\\

(1)double sum=0.0;

(2)sum/=c;

解析:(1)变量定义错误,变量sum存放所有数据的和,应定义为double型。

(2)c语言中的除法运算符是“/”。

程序设计题

3.规定输入的字符串中只包含字母和*号。请编写函数fun,其功能是:使字符串的前导木号不得多于n个,若多于n个,则删除多余的*号;若少于或等于n个,则不做处理。字符串中间和尾部的*号不删除。

例如,字符串中的内容为“*******A*BC*DEF*G****”,若n的值为4,删除后,字符串中的内容应当是“****A*BC*DEF*G****”;若n的值为8,则字符串中的内容仍为“*******A* BC*DEF*G****”。n的值在主函数中输入。在编写函数时,不得使用C语言提供的字符串函数。

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

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

试题程序:

#include<stdio.h>

#include<conio.h>

void fun(char*a,int n)

{

}

void main()

{

char s[81]; int n;

printf(\\

void fun(char*a,int n)

{

int i=0,k=0;

char*p, *t;

p=t=a; /*开始时,p与t同时指向数组的首地址*/

while(*t==’*’) /*用k来统计前部星号的个数*/

{k++;t++;}

if(k>n) /*如果k大于n,则使p的前部保留n个星号,其后的字符依次存入数组a中*/

{while(*p)

{a[i]=*(p+k—n);

i++;

p++;

}

a[i]=’\0’; /*在字符串最后加上结束标识*/

}

}

解析:字符串中前导*号不能多于n个,多余的应删除。首先需要通过while循环统计字符串前导*号的个数,然后通过if条件语句完成前导*号的个数和n的比较,如果前导*号多于n个,需要把n个*号和其余字符重新保留。

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

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

推荐资源

客服

扫码添加客服微信

热线

官方客服

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

电话客服:

客服微信:pujinet

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

公众号

扫码关注微信公众号