首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
使用VC++2010打开考生文件夹下modi1中的解决方案。此解决方案的项目中包含一个源程序文件modi1.c。在此程序中,规定输入的字符串全部为字母,fun函数的功能是:统计a所指字符串中每个字母在字符串中出现的次数(统计时不区分大小写),并将出现次数最
使用VC++2010打开考生文件夹下modi1中的解决方案。此解决方案的项目中包含一个源程序文件modi1.c。在此程序中,规定输入的字符串全部为字母,fun函数的功能是:统计a所指字符串中每个字母在字符串中出现的次数(统计时不区分大小写),并将出现次数最
admin
2018-08-11
38
问题
使用VC++2010打开考生文件夹下modi1中的解决方案。此解决方案的项目中包含一个源程序文件modi1.c。在此程序中,规定输入的字符串全部为字母,fun函数的功能是:统计a所指字符串中每个字母在字符串中出现的次数(统计时不区分大小写),并将出现次数最高的字母输出(如果有多个相同,输出一个即可)。
例如对于字符串:dadbedbabdb,对应的输出应为:b或d。
请改正函数fun中指定部位的错误,使它能得出正确的结果。
注意:不要改动main函数,不得增行或删行,也不得更改程序的结构。
试题程序:
#include<stdio.h>
#include<stdio.h>
#include<string.h>
void fun(char a[])
{int b[26],i,n,max;
for(i=0;i<26;i++)
/*********found*********/
a
=0;
n=strlen(a);
for(i=0;i<n;i++)
if(a
>=’a’&&a
<=’z’)
/*********found*********/
b[a
-’A’]++;
else if(a
>=’A’&&a
<=’Z’)
b[a
-’A’]++;
max=0;
for(i=1;i<26;i++)
/*********found*********/
if(b[max]>b
)
max=i;
printf("出现次数最多的字符是:%c\n’,max+’a’);
}
main()
{char a[200];
printf("请输入一个待统计的字符串:");scanf("%s",a);
fun(a);
}
选项
答案
(1)b[i]=0; (2)b[a[i]-’a’]++; (3)if(b[max]<b[i])
解析
要统计字符串中每个字符在这个字符串中出现的次数,可以设数组b中存放每个字符出现的次数b[0]存放字符a的次数,b[1]存放字符b的次数……。统计之前为数组b各元素赋初值为0。然后依次取出字符串的每个字符进行判断,使对应数组b加1。max初始值为0,与数组b中的每个元素进行比较,如果小于,就把下标进行交换。
(1)数组a存放的是字符串,数组b为整型数组存放的是每个字符的个数,应将数组b每个元素初始化为0。
(2)小写字母的ASCII码减去’a’的ASCII即为相应字母的下标值,相应下标值的数组元素的值增加1。
(3)最大值小于被比较数时,把被比较数的下标值赋给max,max中存放的总是当前最大值。
转载请注明原文地址:https://kaotiyun.com/show/ljxp777K
本试题收录于:
二级C语言题库NCRE全国计算机二级分类
0
二级C语言
NCRE全国计算机二级
相关试题推荐
有以下程序:main(){chark;inti;for(i=1;i<3;i++){scanf("%c",&k);switch(k){
在下列选项中,没有构成死循环的程序段是()。
以下程序中函数f的功能是将n个字符串按由大到小的顺序进行排序。#include<string.h>voidf(charp[][10],intn){chart[20];inti,j;for(i=0;i<n-1;i++)
若有语句:inti=-19,j=i%4;printf("%d\n",j);则输出结果是【】。
以下程序运行后输入3,abcde<回车>,则输出结果是【】。#include<string.h>move(char*str,intn){chartemp;inti;temp=str[n-1];for
若有定义和语句:() int**pp,*p,a=10,b=20 pp=&p;p=&a;p=&b;printf("%d,%d”n",*p,**pp); 则输出结果是
有下列程序:#include"stdio.h"main(){intx=0;inty=0;while(x<7&&++y){y--;x++;}pri
设变量均已正确定义,若要通过scanf("%d%c%d%c",&a1,&c1,&a2,&c2);语句为变量a1和a2赋数值10和20,为变量c1和c2赋字符X和Y。以下所示的输入形式中正确的是(注:□代表空格字符)
在计算机中,字符的比较是对它们的【】进行比较。
以下定义的结构体类型拟包含两个成员,其中成员变量info用来存入整形数据;成员变量link是指向自身结构体的指针,请将定义补充完整。structnode{intinfo;【】link;};
随机试题
男性32岁,反复上腹痛二年余,向背部放射,夜间加重,曾二次大出血,经抢救治愈,最可能的诊断是
InBritain,thebestseasonoftheyearisprobably______spring.
男性25岁,在闭合环境内氧气燃烧爆炸致轻度吸入性损伤烧伤面积40%伤后15分钟入院。查体:口唇咽部黏膜苍白肿胀,鼻毛烧焦,两肺听诊正常,正规液体复苏,伤后48小时突然出现呼吸困难,出现"三凹"症,听诊为吸气性哮鸣音。
A、安坤颗粒B、益母草膏C、七制香附丸D、妇科十味片E、少腹逐瘀丸用于治疗寒凝血瘀所致月经不调的中成药是
患者入院时进行的初步护理的内容包括()。
如果纳税义务人自缴款期限届满之日起()内仍未缴税款,经海关关长批准,海关可以采取强制措施。
骆驼(CAMEL)分析系统中,“E”代表()。
当时不少学生在周记中给我______提意见:老师,你对那些调皮的学生太好了,你要更厉害一些。领导也不断______我们这些年轻教师,一定要严格管理学生,只有严格才能出成绩。依次填入画横线部分最恰当的一项是()。
下列关于辩证唯物主义能动反映论和旧唯物主义直观反映论的区别中,表述正确的有()
Jackwasoutofmoney.Hehadacardontheboardannouncingthathehadaradioset______.
最新回复
(
0
)