字符统计2 (Java实现)

 
Problem Description

输入英文句子,输出该句子中除了空格外出现次数最多的字符及其出现的次数。

Input

输入数据包含多个测试实例,每个测试实例是一个长度不超过100的英文句子,占一行。

Output

逐行输出每个句子中出现次数最多的字符及其出现的次数(如果有多个字符的次数相同,只输出ASCII码最小的字符)。

Sample Input
I am a student
a good programming problem
ABCD abcd ABCD abcd
Sample Output
a 2
o 4
A 2
Hint
 
Source
 1 import java.util.Scanner;
 2 
 3 public class Main {
 4     public static void main(String[] args) {
 5         Scanner sc = new Scanner(System.in);
 6         while (sc.hasNext()){
 7             int[] lowNum =new int[26];  // 储存大写字母出现次数
 8             int[] upNum =new int[26];  // 储存小写字母出现个数
 9             String str = sc.nextLine();
10             int maxCount = 0;
11             char ma = 'A';
12             char[] ch = str.toCharArray();
13             for (int i = 0; i < str.length(); i++) {  // 遍历字符串
14                 if (ch[i] >= 'A' && ch[i] <= 'Z'){  // 对大写字母进行统计
15                     upNum[ch[i]-65]++;
16                     if (maxCount <= upNum[ch[i]-65]){  // 若出现次数相同,还需为ascii值进行判断,分两种情况
17                         if (maxCount == upNum[ch[i]-65]  // 第一种,若出现次数相同,而刚统计的字母ascii值较小,则进行记录
18                         && ch[i] < ma){  
19                             maxCount = upNum[ch[i]-65];
20                             ma = ch[i];
21                         }
22                         else if (maxCount < upNum[ch[i]-65]){  // 第二种,若新统计的字母出现次数大于最大次数,则记录
23                             maxCount = upNum[ch[i]-65];
24                             ma = ch[i];
25                         }
26                     }
27                 }
28                 else if (ch[i] >= 'a' && ch[i] <= 'z'){
29                     lowNum[ch[i]-97]++;
30                     if (maxCount <= lowNum[ch[i]-97]){
31                         if (maxCount == lowNum[ch[i]-97]
32                         && ch[i] < ma){
33                             maxCount = lowNum[ch[i]-97];
34                             ma = ch[i];
35                         }
36                         else if (maxCount < lowNum[ch[i]-97]){
37                             maxCount = lowNum[ch[i]-97];
38                             ma = ch[i];
39                         }
40                     }
41                 }
42             }
43             System.out.printf("%s %d\n", ma, maxCount);
44         }
45     }
46 }
 
 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值