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

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

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

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

程序填空题

1.下列给定程序中,函数fun的功能是:把形参a所指数组中的最小值放在元素a[0]中,接着把a所指数组中的最大值放在a[1]元素中;再把a所指数组元素中的次小值放在a[2]中,把a所指数组元素中的次大值放在a[3],依此类推。

例如,若a所指数组中的数据最初排列为:9,1,4,2,3,6,5,8,7;则按规则移动后,数据排列为:1,9,2,8,3,7,4,6,5。形参n中存放a所指数组中数据的个数。

规定fun函数中的max存放当前所找的最大值,px存放当前所找最大值的下标。

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

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

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

试题程序:

#include<stdio.h>

#define N 9

void fun(int a[],int n)

{ int i,j,max,min,px,pn,;

for(i=0;i<n-1;i+=2)

{

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

max=min=【1】

px=pn=i;

for(j=i+1;j<n;j++) {

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

if(max<【2】)

{max=a[j];px=j;)

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

if(min>【3】)

{ min=a[j];pn=j;}

}

if(pn!=i)

{t=a[i];a[i]=rain;a[pn]=t;

if(px==i)px=pn;

}

if(px!=i+1)

{ t=a[i+1],a[i+1]=max;

a[px]=t;)

}

}

void main()

( int b[N]={9,1,4,2,3,6,5,8,7),i;

printf(\\

(1)a[i]

(2)a[j]

(3)a[j]

解析:本题考查:数组的引用;if语句条件表达式,如果表达式的值为真,则执行下面的语句,如果该值为假,则不执行下面的语句。

填空1:for循环语句循环体中将数组元素a[i]赋值给变量max和变量min。

填空2:通过一次for循环,找到数组中的最大值,if语句的条件表达式是max<a[j]。

填空3:同理,此处if语句的条件表达式是min>a[j]。

求最大值或者最小值的题目,一般都是先假设一个元素最大或最小,然后通过if条件语句将该元素和其他元素进行比较操作来完成。

程序修改题

2.下列给定程序中函数fun的功能是:在字符串的最前端加入n个*号,形成新串,并且覆盖原串。字符串的长度最长允许为79。

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

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

试题程序:

#include<stdio.h>

#include<string.h>

void fun(char s[],int n)

{

char a[80],*p;

int i;

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

s=p;

for(i=0;i<n;i++)a[i]=’*’;

do

{ a[i]=*p;

i++;

}

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

while(*P++)

a[i]=0;

strcpy(s,a);

}

main()

{ int n;char s[80];

printf(\\

(1)p=s;

(2)while(*p++);

解析:(1)指针p应指向s,所以应改为p=s;。

(2)循环等待,当while循环执行一次,临时变量p应该指向字符串的下一位置,所以应改为while(*p++);。

程序设计题

3.编写—个函数,其功能是:从传入的num个字符中找出最长的一个字符串,并通过形参指针max传回该串地址(用****作为结束输入的标识)。

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

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

试题程序:

1 #include<conio.h>

2 #include<stdio.h>

3 #include<string.h>

4 #include<stdlib.h>

5 char*fun(char(*a)[81],int num,char * max)

6 {

7

8 }

9 void main()

10 {

11 FILE*wf;

12 char ss[10][81],*ps=NULL;

13 char s[3][81]={\\

char *fun(char(*a)[81],int num,

char *max)

{

int i=0;

max=a[0];

for(i=0;i<num;i++) /*找出最长的一个字符串*/

if(strlen(max) <strlen(a[i]))

max=a[i];

return max;/*传回最长字符串的地址*/

}

解析:首先应该明白ss是一个指向一维数组的指针变量,max是指向指针的变量,所以引用变量时要注意加上*。本程序使用循环语句遍历字符串数组,使用条件语句判断该字符串是否最长。

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

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

推荐资源

客服

扫码添加客服微信

热线

官方客服

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

电话客服:

客服微信:pujinet

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

公众号

扫码关注微信公众号