zoukankan      html  css  js  c++  java
  • 字符统计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
    ", ma, maxCount);
    44         }
    45     }
    46 }
    
    
  • 相关阅读:
    Java中swing常用控件背景设置透明的方法
    SpringMVC工作原理
    关于spring框架工作原理
    Java-JFrame窗体美化方式
    Java swing GUI窗口美化
    Java-Swing是什么?
    SSM+Redis+Layui前端框架实现验证码的发送
    SSM+Redis+Layui实现注册功能
    SSM+Layui实现模拟登录功能
    SSM+layui分页(了解98%)
  • 原文地址:https://www.cnblogs.com/sugerandmaster/p/11484698.html
Copyright © 2011-2022 走看看