首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
阅读以下说明和C代码,填写代码中的空(1)~(6),将解答写入答题纸的对应栏内。 【说明】 下面的C代码在输入的100个英文单词中找出最小单词和最大单词。约定每个单词是仅由英文字母构成的字符串,且都不超过20个字符。单词的大小按照字典序定义。例弧,
阅读以下说明和C代码,填写代码中的空(1)~(6),将解答写入答题纸的对应栏内。 【说明】 下面的C代码在输入的100个英文单词中找出最小单词和最大单词。约定每个单词是仅由英文字母构成的字符串,且都不超过20个字符。单词的大小按照字典序定义。例弧,
admin
2020-04-30
36
问题
阅读以下说明和C代码,填写代码中的空(1)~(6),将解答写入答题纸的对应栏内。
【说明】
下面的C代码在输入的100个英文单词中找出最小单词和最大单词。约定每个单词是仅由英文字母构成的字符串,且都不超过20个字符。单词的大小按照字典序定义。例弧,单词“entry”大于“enter”“art”小于“article”“an”等于“An”,
【C代码】
#include
#define NUMBER 100
int isValid(const char *s1);//若字符串s1仅包含英文字母则返回1,否则返回0
char toLower(char ch); //将大写字母转换为小写字母
int usr_strcmp(char*s1,char*s2);//比较字符串s1和s2,相等时返回0,
//s1大则返回正整数,s1小则返回负整数
void usr strcpy(char*s1,const char*s2); //字符串s2拷贝给s1
int main()
{ char word[32];
char maxWord[32]="",minWord[32]="";
int numWord=0;
while(numWord<NUMBER){
scanf("%s", (1) ); //输入一个单词存入word
if(isValid(word)) {
if(0==numWord){usr_strcpy(minWord,word); usr strcpy(maxWord,word);}
numWord++;
if( (2) >0) //调用usr_strcmp比较单词
usr_strcpy(maxWord,word); //m maxWord记下最大单词
else
if( (3) <0) //调用usr_strcmp比较单词
usr strcpy(minWord,word); //用minWord记下最小单词
}
}
printf("maxWord=%s minWord=%s\n",maxWord,minWord);
return 0;
}
int isValid(const char*s)
{
for(;*s ; s++)
if(!(*s>=’a’&&*s<=’z’)&&!(*s>=’A’&&*s<=’Z’))
return 0;
return 1;
}
char toLower(char ch)
{ //若ch为大写字母则返回其小写形式,否则直接返回原字符
if(ch>=’A’&&ch<=’Z’)
ch= (4) +’a’;
return ch,
}
int usr strcmp(char*s1,char*s2)
{ //按字典序比较两个英文单词,若s1表示的单词大,则返回正整数,
//若s1表示的单词小,则返回负整数;否则返回0
for(; (5) ; ){
if (toLower(*s1)==toLower(*s2)) {s1++, s2++;}
else
break;
}
return(toLower(*s1)一toLower(*s2));
}
Void usr_strcpy(char *s1, const char *s2)
{ //将s2表示的字符串复制给s1
for(; (6) ; )
★s1++= ★s2++;
*s1= ’\0’;
}
选项
答案
(1)word或等效形式 (2)usr_strcmp(word,maxWord) (3)usr_strcmp(word,minWord) (4)ch一’A’或ch一65或等效形式 (5)*s1&&*s2或*s1!=’\0’&&*s2!=’\0’或等效形式 注:*s1可替换为s1[0]、*s2可替换为s2[0],’\0’可替换为0 (6)*s2或s2[0]或等效形式
解析
本题考查C程序流程控制、函数定义及调用和字符串运算。
在main函数中输入字符串,并调用字符串比较函数来判断两个字符串的大小关系,输入的第一个字符串既是最大的单词maxWord,也是最小的单词minWord。
代码中通过调用用户自定义函数的ust stromp(char*s1,char*s2)进行字符串的比较,使用自定义函数usr_strcpy(char*s1,const char*s2)实现字符串的复制。根据函数声明,当字符串s1和s2相等时函数usr strcmp返回0,s1大则返回正整数,s1小则返回负整数。
空(1)处应填入“word”或其等效形式“&word”。
空(2)处比较word和maxWord的大小,当word大于maxWord时更新maxWord的内容,即调用usr strcmp的结果应大于0,所以调用表达式为“usr_strcmp(word,maxWord)”,两个参数次序不正确时,其结果与程序要求的处理逻辑不相符。同理,空(3)处比较word和minWord的大小,当word小于minWord时更新minWord的内容,因此该空应填入“usr strcmp(word,minWord)”。
空(4)所在函数将大写字母转换为小写字母。在ASCII字符表中,大写字母“A”的编码是十进制数65,字母“B”的编码为66,依次类推,字母“Z”的编码为90;而小写字母“a”的编码是十进制数97,字母“b”的编码为98,其他小写字母依次类推。根据字母的编码规律可知,将大写字母的编码减去“A”的编码即可得到该字母的序号(从0开始),再加上小写字母“a”的编码,即可得到对应的小写字母编码,因此空(4)应填入“ch-‘A’”或其等效形式。
空(5)所在的函数实现两个字符串的比较,过程是两个字符串的第一个字符进行比较,若相同则继续比较它们的第二个字符,若不同则可以结束,然后根据这两个不同字符的大小来确定对应字符串的大小。如果其中的一个字符串先结束,则先结束的字符串小于另一个字符串,所以空(5)处应填入“*s1&&*s2”或其等效形式,确保所比较的两个字符串都可提供进行比较的字符。
空(6)所在的函数进行字符串复制处理,通过逐个字符的复制来完成,显然for语句的循环条件是被复制的字符串未结束,因此空(6)应填入“*s2”或其等效形式。
转载请注明原文地址:https://kaotiyun.com/show/L2jZ777K
本试题收录于:
程序员下午应用技术考试题库软考初级分类
0
程序员下午应用技术考试
软考初级
相关试题推荐
某个字段的数据是原始数据计算的结果,该字段的宽度和小数位数对数据的精度有影响。一般来说,小数位数的确定需要考虑______。
在PowerPoint中,执行插入新幻灯片的操作后,被插入的幻灯片将出现在(53)。
打开DOC文档48.doc,有如下表格,欲在空白单元格中计算出整行其他四个单元格的数值之和,应在空白单元格中插入公式(48)。
计算机病毒是一段程序,一般隐藏在______中。
收集数据时,设计调查的问题很重要。此时,需要注意的原则不包括(8)。
信息处理工作前期,首先需要收集所需的数据,常常要做原始统计记录。做原始统计记录需要注意的事项中一般不包括(32)。
程序员一般用(7)软件编写和修改程序。
在Exeel2010中,___________可以对A1单元格数值的小数部分进行四舍五入运算。
请根据网页显示的效果图和网页中的元素说明,将HTML文本中(n)处的解答填入答题纸对应的解答栏内。说明在Ⅲ浏览器中输入常春藤大学招生办公室主页的网址并回车后,网页显示的效果如图5-1所示。HTML文本<html><he
综合布线系统由6个子系统组成,将图1-1中(1)~(6)处空缺子系统的名称填写在答题纸对应的解答栏内。为满足公司要求,通常选用什么类型的信息插座?
随机试题
外圆磨床试运行时,不必进行空运转试验。()
设函数f(x)=,若x=1为其可去间断点,则常数a,b的值分别为()
ThecostoflivinginGlasgowisamongthelowestinBritain,________thequalityoflifeisprobablyoneofthehighest.
男性,68岁。因持续性胸骨后疼痛8小时来急诊。查体:双肺底有少量湿啰音,诊断为急性心肌梗死。该患者心功能的分级是
踝足部内翻损伤不可能出现的是:
原发于内分泌腺的疾病肿瘤引起的异位性内分泌病综合征
患者,女,67岁。腹水1个月伴消瘦、乏力、腹胀。腹水病理检查找到癌细胞,血清CEA(+),大便检查有许多红细胞、白细胞及脓细胞,细菌培养无痢疾杆菌,用抗生素治疗无效。B超检查为双侧卵巢占位性病变。最可能的诊断是
下表列示了对证券A的未来收益率状况的估计:则证券A的期望收益率和方差分别为()。
上海东方明珠广播电视塔2006年被评为国家5A级旅游区。()
WhenJoangavebirth【C1】______thefirstboyinherfamilyinthreegenerations,sheandherhusbandwereecstatic.【C2】______were
最新回复
(
0
)