给定一个只包含大写字母的字符串S,请你输出其中出现次数最多的字母。如果有多个字母均出现了最多次,按字母表顺序依次输出所有这些字母。输入一个只包含大写字母的字符串S。输出若干个大写字母,代表答案,样例输...
时间: 2024-05-16 19:18:25 浏览: 126
好的,这是一道简单的字符串统计题目。我们可以使用一个哈希表来记录每个字母出现的次数,然后找到出现次数最多的字母并输出。
以下是Python的代码实现:
```python
S = input() # 输入字符串S
count = {} # 定义一个空的哈希表
# 遍历字符串S中的每个字符
for c in S:
if c in count:
count[c] += 1 # 如果该字符已经在哈希表中,次数加1
else:
count[c] = 1 # 否则将该字符添加到哈希表中,次数初始化为1
max_count = max(count.values()) # 找到出现次数最多的字母的出现次数
# 输出所有出现次数为max_count的字母,按字母表顺序
for c in sorted(count):
if count[c] == max_count:
print(c, end='')
```
例如,对于输入字符串`ABBCCCDDDDEEEEE`,输出结果为`E`。
如果输入字符串`ABCABCABC`,输出结果为`ABC`。
相关问题
使用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的字母及其出现次数。
阅读全文