Java给定一个只包含大写字母的字符串S,输出次数最多的字母
时间: 2024-06-14 14:03:37 浏览: 194
以下是Java输出次数最多的字母的代码:
```java
String str ="aaaaaaaccccccccccccccccccccccaaaabb";
int[] count = new int[26];
for(int i=0;i<str.length();i++){
count[str.charAt(i)-'A']++;
}
int max = 0;
int position = 0;
for(int i=0;i<count.length;i++){
if(count[i]>max){
max = count[i];
position = i;
}
}
System.out.println("字母"+(char)(position+65) +"出现"+ max +"次");
```
输出结果为:字母C出现18次。
相关问题
使用Java完成:给定一个只包含大写字母的字符串S,请你输出其中出现次数最多的字母。如果有多个字母均出现了最多次,按字母表顺序依次输出所有这些字母。输入一个只包含大写字母的字符串S。输出若干个大写字母,代表答案,样例输...
可以使用一个HashMap来记录每个字母出现的次数,然后遍历HashMap找到出现次数最多的字母。如果有多个字母出现次数相同,则可以将它们放到一个列表中,最后按字母表顺序输出这个列表。
下面是Java代码实现:
```java
import java.util.*;
public class Main {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
String s = sc.nextLine();
Map<Character, Integer> map = new HashMap<>();
int maxCount = 0;
for (int i = 0; i < s.length(); i++) {
char c = s.charAt(i);
int count = map.getOrDefault(c, 0) + 1;
map.put(c, count);
maxCount = Math.max(maxCount, count);
}
List<Character> list = new ArrayList<>();
for (Map.Entry<Character, Integer> entry : map.entrySet()) {
if (entry.getValue() == maxCount) {
list.add(entry.getKey());
}
}
Collections.sort(list);
for (char c : list) {
System.out.print(c);
}
}
}
```
输入样例:
```
ABCAABBCCC
```
输出样例:
```
C
```
Java给定一个只包含大写字母的字符串S,请你输出其中出现次数最多的字母,如果有多个字母均出现了最多次,按字母表顺序依次输出所有这些字母
以下是Java输出字符串中出现次数最多的字母的代码:
```java
String s = "ABCAABBCCC";
int[] count = new int[26];
int max = 0;
for (int i = 0; i < s.length(); i++) {
char c = s.charAt(i);
count[c - 'A']++;
max = Math.max(max, count[c - 'A']);
}
for (int i = 0; i < 26; i++) {
if (count[i] == max) {
System.out.println("字母" + (char)(i + 'A') + "出现" + max + "次");
}
}
```
代码解释:
1. 首先定义一个长度为26的数组count,用于记录每个字母出现的次数。
2. 遍历字符串s,对于每个字符c,将其对应的count数组位置加1。
3. 同时记录出现次数的最大值max。
4. 再次遍历count数组,输出出现次数等于max的字母及其出现次数。
阅读全文