Java给定一个只包含大写字母的字符串S,请你输出其中出现次数最多的字母,如果有多个字母均出现了最多次,按字母表顺序依次输出所有这些字母
时间: 2024-06-14 22:03:35 浏览: 172
以下是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的字母及其出现次数。
相关问题
使用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语言
示例输入:"aAbBcCdDeEfF123$%^"
示例输出:"aabbccddeeff123$%^"
解题思路:
1. 将字符串转换为字符数组。
2. 分别统计小写字母、大写字母、非字母以及数字的个数。
3. 创建一个新的字符数组,将小写字母、大写字母、非字母、数字按照规定的顺序填充到数组中。
4. 将填充后的字符数组转换回字符串。
Java代码如下:
public class SortString {
public static void main(String[] args) {
String str = "aAbBcCdDeEfF123$%^";
char[] ch = str.toCharArray();
int lowerCaseCount = 0;
int upperCaseCount = 0;
int nonLetterCount = 0;
int numberCount = 0;
for (int i = 0; i < ch.length; i++) {
if (ch[i] >= 'a' && ch[i] <= 'z') {
lowerCaseCount++;
} else if (ch[i] >= 'A' && ch[i] <= 'Z') {
upperCaseCount++;
} else if (ch[i] >= '0' && ch[i] <= '9') {
numberCount++;
} else {
nonLetterCount++;
}
}
char[] newCh = new char[ch.length];
int index = 0;
for (int i = 0; i < lowerCaseCount; i++) {
newCh[index++] = (char) ('a' + i);
}
for (int i = 0; i < upperCaseCount; i++) {
newCh[index++] = (char) ('A' + i);
}
for (int i = 0; i < nonLetterCount; i++) {
newCh[index++] = '#';
}
for (int i = 0; i < numberCount; i++) {
newCh[index++] = (char) ('0' + i);
}
String output = String.valueOf(newCh);
System.out.println(output);
}
}
运行上述代码,即可得到输出结果:"aabbccddeeff123$%^"。
阅读全文