PAT Basic 1042. 字符统计(20)(C语言实现)
2017-05-18 23:46
435 查看
题目
请编写程序,找出一段给定文字中出现最频繁的那个英文字母。输入格式:
输入在一行中给出一个长度不超过1000的字符串。字符串由ASCII码表中任意可见字符及空格组成,至少包含1个英文字母,以回车结束(回车不算在内)。
输出格式:
在一行中输出出现频率最高的那个英文字母及其出现次数,其间以空格分隔。如果有并列,则输出按字母序最小的那个字母。统计时不区分大小写,输出小写字母。
输入样例:
This is a simple TEST. There ARE numbers and other symbols 1&2&3...........
输出样例:
e 7
思路
这道题也是够简单。开一个int[26]记录字母出现次数。
找最大值的时候从后向前找,找到的就是最大值中字母序最小的。
代码
最新代码@github,欢迎交流 ^_^#include <stdio.h> #include <ctype.h> int main() { char c; int count[26] = {0}, max = 25; while((c = getchar()) != '\n') if(isalpha(c)) count[tolower(c) - 'a']++; /* find forward from end in case there are multiple maximums */ for(int i = 25; i >= 0; i--) if(count[i] >= count[max]) max = i; printf("%c %d", max + 'a', count[max]); return 0; }
相关文章推荐
- PAT (Basic Level) Practise (中文)1042. 字符统计(20) C语言
- PAT BASIC LEVEL 1042. 字符统计(20)
- PAT(basic level) 1042 字符统计(20)
- PAT乙级1042(C语言)-字符统计(20)
- PAT Basic 1038. 统计同成绩学生(20)(C语言实现)
- 1042. 字符统计(20)-浙大PAT乙级真题java实现
- PAT (Basic Level) Practise (中文)1042. 字符统计(20)
- PAT (Basic Level) Practise (中文) 1042. 字符统计(20)
- PAT (Basic Level) Practise (中文)1042. 字符统计(20)
- PAT Basic 1002. 写出这个数 (20)(C语言实现)
- PAT Basic 1013. 数素数 (20)(C语言实现)
- PAT Basic 1012. 数字分类 (20)(C语言实现)
- PAT Basic 1018. 锤子剪刀布 (20)(C语言实现)
- 1042. 字符统计(20) PAT 乙级
- PAT-乙级-1042. 字符统计(20)
- PAT-B 1042. 字符统计(20)
- PAT 乙级 1042. 字符统计(20)
- PAT 1042. 字符统计(20)
- 浙江大学PAT_乙级_1042. 字符统计(20)
- PAT 乙级 1042. 字符统计(20)