![](/img/trans.png)
[英]Check whether list of custom objects have same value for a property in Java 8
[英]Counting objects with a same property value
我正在创建一个扑克排名求解器,我必须在一组牌中计算具有相同套装或同等级别的牌。 在这里,如果集合中有多个排名,我会创建HashMap
并增加值。
private boolean isFourOfAKind() {
Map<RANK, Integer> rankDuplicates = new HashMap<>();
for(Card card : cards) {
rankDuplicates.put(card.getRank(), rankDuplicates.getOrDefault(card.getRank(), 0) + 1);
}
return rankDuplicates.containsValue(4);
}
我想知道是否有可能使用流与java流完全相同的事情。 它看起来像这样:
private boolean isFourOfAKind() {
Map<RANK, Integer> rankDuplicates = cards.stream()
.map(Card::getRank)
.collect(Collectors.toMap(/*...something goes here..*/)); // of course this is very wrong, but you can see what I'm aiming at.
return rankDuplicates.containsValue(4);
}
看起来你正在寻找类似的东西
return cards.stream()
.collect(Collectors.toMap(Card::getRank, e -> 1, Integer::sum))
// keyMapper, valueMapper, mergeFunction
.containsValue(4);
groupingBy
另一个变种:
import static java.util.stream.Collectors.counting;
import static java.util.stream.Collectors.groupingBy;
...
private boolean isFourOfAKind() {
return cards.stream()
.collect(groupingBy(Card::getRank, counting()))
.containsValue(4L);
}
基本上你按照等级对牌进行分组,这样你就可以得到Map<Rank, List<Card>>
然后使用下游收集器counting()
将每个列表映射到其元素数,以便最终结果是Map<Rank, Long>
(您也可以使用summingInt(i -> 1)
而不是summingInt(i -> 1)
counting()
你真的需要一个Map<Rank, Integer>
)。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.