国家二级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版点下载