【发布时间】:2017-10-20 09:41:16
【问题描述】:
我有一个包含排名数字的数组。
类似这样的:
0 4 2 0 1 0 4 2 0 4 0 2
这里0对应最低等级,max数字对应最高等级。可能有多个索引包含最高排名。
我想找到数组中所有最高排名的索引。我通过以下代码实现了:
import java.util.*;
class Index{
public static void main(String[] args){
int[] data = {0,4,2,0,1,0,4,2,0,4,0,2};
int max = Arrays.stream(data).max().getAsInt();
ArrayList<Integer> indexes = new ArrayList<Integer>();
for(int i=0;i<12;i++){
if(data[i]==max){
indexes.add(i);
}
}
for(int j=0;j<indexes.size();j++){
System.out.print(indexes.get(j)+" ");
}
System.out.println();
}
}
我得到的结果是:1 6 9
还有比这更好的方法吗?
因为,就我而言,可能存在一个包含数百万个元素的数组,因此我在性能方面存在一些问题。
所以,
欢迎提出任何建议。
【问题讨论】:
-
流式传输一些开销,因此用常规的
for循环替换该流行,以找到最大值,可能会稍微提高性能。否则,可能不会,但你为什么不分析代码,看看是否有任何弹出? -
您的问题是您对数组进行了两次迭代——一次是为了找到最大值,然后一次是为了找到它的所有实例。你真的只需要遍历数组一次。
-
这是样例。我从一个函数中得到了一个数组,该函数的大小通常很大,这是整个执行的一部分,我想改进
标签: java arrays java-stream