我正在用Java编写一个Pokergame,我在编写手工评估时遇到了困难。我正在考虑写一个函数,它返回带相同西装的卡片数,以便首先检查冲水情况。我有一张带套头衫和getSuit的班级卡。在我的评估器中,我想要一个方法countSuits(),它返回一个整数值,其匹配量最大。我可以像这样分别检查每一套西装:
Arrays.stream(cards).filter(card -> card.getSuit()== Card.Suit.DIAMOND).count(); 然后比较返回值并返回最高值,但是我想找到一个解决方案,用一个流来完成这个任务。
这有可能吗?我还有点想了解溪流..。
发布于 2019-07-03 16:24:10
您可以使用groupingBy按套装分组,然后使用counting作为下游,查找列表中每一套西装的卡数:
Map<Suit, Long> collect = cards.stream()
.collect(Collectors.groupingBy(Card::getSuit, Collectors.counting()));有关groupingBy()和counting(),请参见java文档
为了确保手上有5套西装,你可以检查一下:
if (collect.values().contains(5L)) {...}https://stackoverflow.com/questions/56874240
复制相似问题