说我有一个包含元素的列表(34,11,98,56,43).
使用Java 8流,我如何找到列表的最小元素的索引(在这种情况下为1)?
我知道这可以在Java中使用list.indexOf(Collections.min(list))轻松完成.但是,我正在看一个像Scala一样的解决方案,我们可以简单地说出List(34,43).zipWithIndex.min._2来获取最小值的索引.
有没有什么可以使用流或lambda表达式(比如Java 8的特定功能)来实现相同的结果.
注意:这只是为了学习目的.我在使用Collections实用程序方法时没有任何问题.
解决方法
import static java.util.Comparator.comparingInt; int minIndex = IntStream.range(0,list.size()).Boxed() .min(comparingInt(list::get)) .get(); // or throw if empty list
正如@TagirValeev在his answer提到的,您可以通过使用IntStream#reduce而不是Stream#min来避免拳击,但是以掩盖意图为代价:
int minIdx = IntStream.range(0,list.size()) .reduce((i,j) -> list.get(i) > list.get(j) ? j : i) .getAsInt(); // or throw