我有一个实现可以在String
中找到重复的字符:
Map<Character, Integer> charMap = new HashMap<>();
for (int i = 0; i < word.length(); i++) {
Character ch = word.charAt(i);
if (charMap.containsKey(ch)) {
charMap.put(ch, charMap.get(ch) + 1);
} else {
charMap.put(ch, 1);
}
}
我想知道是否可以将此实现转换为
Java 8
和Stream
实现。做这样的事情:Map<Character, Integer> charMap = new HashMap<>();
然后将
String
word
转换为字符的List
:List<Character> chars = word.chars()
.mapToObj(i -> (char) i)
.collect(Collectors.toList());
现在要做类似的事情:
chars.stream()
.filter(e -> charMap.containsKey(e))...
最佳答案
您可以使用此:
Map<Character, Integer> charMap = new HashMap<>();
String word = "acbczabcd";
word.chars().forEach(ch -> charMap.put((char) ch, charMap.getOrDefault((char) ch, 0) + 1));
,带有
mapToObj
word.chars().mapToObj(n -> (char) n).forEach(ch -> charMap.put(ch, charMap.getOrDefault(ch, 0) + 1));