-
题目要求先找出字符串中出现次数最多的字母r,然后在输出每一个r时输出(出现了x次)。D题的要点在于如何找到字符串中出现次数最多的字母。
-
如果要得到出现次数最多的字母r,则先要得到字符串中每一个字符的出现次数,然后通过比较得到字母r。
for(i=0; i<len; i++) {
mark=list[i];//标记每一个字符
recording=0;//标记每一个字符出现的次数
for(j=i; j<len; j++) {
if(list[j]==mark) {
recording++;//记录每一个字母出现的次数
}
if(recording>max) {//将每一个字母出现的次数与当前已经出现次数最多的字母次数进行比较,如果大于,则该字母为出现次数最多的字母
max=recording;
resort=mark;
}
}
}
- 完整代码如下:
#include<stdio.h>
#include<string.h>
int main() {
char list[200];
char mark,resort;
int recording;
int i,j,len;
int max=0;//标记出现次数最多的字母
while(scanf("%s",list)!=EOF) {
len=strlen(list);//得到字符串长度
for(i=0; i<len; i++) {
mark=list[i];//标记每一个字符
recording=0;//标记每一个字符出现的次数
for(j=i; j<len; j++) {
if(list[j]==mark) {
recording++;//记录每一个字母出现的次数
}
if(recording>max) {//将每一个字母出现的次数与出现次数最多的字母次数进行比较,如果大于,则该字母为出现次数最多的字母
max=recording;
resort=mark;
}
}
}
for(i=0; i<len; i++) {
printf("%c",list[i]);
if(list[i]==resort){
printf("(出现了%d次)",max);//在每一个出现次数最多的字母后加上 (出现了%d次)
}
}
}
}