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

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

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

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

程序填空题

1. 给定程序中,函数fun的功能是:求出形参ss所指字符串数组中最长字符串的长度,将其余字符串右边用字符“*”补齐,使其与最长的字符串等长。ss所指字符串数组中共有M个字符串,且串长<N。

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

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

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

#include

#include

#define M 5

#define N 20

void fun (char (*ss)[N])

{ int i, j, n, len=0;

for(i=0; i<M; i++)

{ len=strlen(ss[i]);

if(i==0) n=len;

if(len>n)n=len;

}

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

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

n=strlen(【1】);

for(j=0; j<len-n; j++)

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

ss[i] [【2】] = ’*’;

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

ss[i] [n+j+ 【3】] = ’\\\\0’;

}

}

main()

{ char ss[M][N]={\\

(1)ss[i] (2)n+j (3)1

解析:函数fun的功能是求出形参ss所指字符串数组中最长字符串的长度。

第一空:第一个循环求最长字符串的长度“len”,在第二个循环内在其他字符串的后面补“*”,使其达到长度“len。”在“for(j:0;j<len-n;j++)”语句中,“j<len-n”是在字符串的后面填“len-n”个“*”,故n是字符串“ss[i]”的长度,因此,第一空应为“ss[i]”。

第二空:循环“for(j=0;j<len-n;j++)”目的是在字符串的后面填len-n个“*”,第二空处应为“n+j”。

第三空:字符串以“\0”结束,因此,需在字符串后加结束符,故第三空应为“1”。

程序修改题

2. 给定程序MODI1.C中fun函数的功能是:将p所指字符串中每个单词的最后一个字母改成大写。(这里的“单词”是指由空格隔开的字符串)。

例如,若输入“I am a student to take the examination.”,则应输出“I aM A studenT tO take thE examination.”。

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

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

#include

#include

#include

void fun(char *p)

{

int k = 0;

for(; *p; p++)

if (k)

{

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

if(p == ’ ’)

{

k = 0;

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

* (p) = toupper(*(p – 1))

}

}

else

k = 1;

}

main ()

{ char chrstr[64];

int d ;

printf(\\

(1)if(*p==’’)

(2)*(p一1)=toupper(*(p一1));

解析:函数的功能是将每个单词的最后一个字母改成大写。

(1)第一个错误标识下的if语句应该是判断字符串中的字符是否是空格,根据“for(;*p;p++)”语句中for循环条件中p的定义应该为字符型指针变量,*p是取p所指存取单元的值,所以“if(p==’’)”应该改为“if(*p==’’)”。

(2)题干中要求是将每个单词的最后一个字母改成大写,所以它的位置应该是挨着空格的前一个字符,应该是指针p指向字符的前一个位置,“*p=toupper(*(p一1))”是将改动的值赋给了p所指的空格,所以应该改为“*(p-1)=toupper(*(p-1));”且语句未尾应有分号。

程序设计题

3. 请编写函数fun,对长度为7个字符的字符串,除首、尾字符外,将其余5个字符按ASCH码降序排列。

例如,原来的字符串为:CEAedca,排序后输出为:CedcEAa。

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

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

#include

#include

#include

void fun(char *s,int num)

{

}

NONO()

{

/*请在此函数内打开文件,输入测试数据,

调用fun函数,输出数据,关闭文件。*/

char s[10] ;

FILE *rf, *wf ;

int i = 0 ;

rf = fopen(\\

char t;

int i,j;

for(i=1;i<num一2;i++)

//对n个元素进行循环选择

for(j=i+1;j<num一1;j++)

if(s[i]<s[j])

//将str[i]设为最大值,和剩下的j~

num一1进行比较

{ t=s[i];

s[i]=s[j];

s[j]=t;

}

解析:选择排序法中的降序排序,首先从数组中挑选一个最大的元素的ascill码,把它和第一个元素交换,接着从剩下的num-1个元素中再挑出一个最大的元素的ascill码,把它和第二个元素交换,不断重复以上过程,直到比较完最后两个元素。

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

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

推荐资源

客服

扫码添加客服微信

热线

官方客服

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

电话客服:

客服微信:pujinet

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

公众号

扫码关注微信公众号