如果有多个结果,则为数组的最低值

时间:2013-09-17 06:05:02

标签: java arrays search arraylist integer

我需要在数组中找到最低值,但我想知道如何处理多个结果。假设我的数组包含[1,4,7,5,3,1] - 我的结果应为1,1。有什么想法吗?

double minimum = array1[0]; //sets the first to be the smallest
for (int i = 0; i < array1.length; i++) //goes through your array
{
 if (array1[i] < array1[0]) //checks and replaces if necessary
 {
    minimum = array[i];   

 }
}

System.out.println( minimum ); //returns the value of the smallest

7 个答案:

答案 0 :(得分:1)

有一件事可以“排序”您的数组按升序排列&amp;然后显示从开始到相等的值

答案 1 :(得分:1)

Arrays.sort(array1);
ArrayList<Integer> smallestValues = new ArrayList<Integer>();
smallestValues.add(array1[0]);
int i=1;
while (i<array1.length && (array1[i] == array1[i-1])) {
     smallestValues.add(array1[i]);
    i++;
 }

答案 2 :(得分:1)

你的代码中有一个小错误,你应该将当前值与最小值进行比较而不是第一个值

double minimum = array1[0]; //sets the first to be the smallest
var minValueCounter = 0;
for (int i = 0; i < array1.length; i++) //goes through your array
{
 if (array1[i] < minimum) //checks and replaces if necessary
 {
    minimum = array[i];  
    minValueCounter  = 1; 

 }
 else if (array1[i] == minimum) //checks and replaces if necessary
 {
    minValueCounter++;

 }
}

答案 3 :(得分:0)

保留另一个变量以计算重复项。如果找到的值等于当前最小值,则递增此计数。请记住每次最小变化时重置计数。

答案 4 :(得分:0)

如何使用Collections.sort()

我假设您的array1[]属于double类型

double array1[] = new double[] { 1, 4, 7, 5, 3, 1 };
ArrayList<Double> al = new ArrayList<Double>();
for (int i = 0; i < array1.length; i++)
    al.add(array1[i]);
Collections.sort(al);
System.out.println(al.toString());

输出:

[1.0, 1.0, 3.0, 4.0, 5.0, 7.0]

要打印所有相等的最小值,请使用

for (int i = 0; i < (al.size() - 1); i++) { // why (al.size() - 1), Its better if try to learn yourself
    if (Double.compare(al.get(i), al.get(i+1))==0)
       System.out.print(""+al.get(i) + "," + al.get(i + 1));
    else
       break;
}

输出:

1.0,1.0

答案 5 :(得分:0)

我会这样做

    int[] a = { 1, 4, 7, 5, 3, 1 };
    Arrays.sort(a);
    int n = 1;
    for (int i = 1; i < a.length && a[i] == a[0]; i++)
        n++;
    int[] res = Arrays.copyOf(a, n);

答案 6 :(得分:0)

只是为了它的乐趣,一个没有for循环的解决方案:

    Integer[] inputA = new Integer[]{1,4,7,5,3,1};
    List<Integer> inputL = Arrays.asList(inputA);        

    Collections.sort(inputL);

    int last = Collections.frequency(inputL, Collections.min(inputL));

    inputA = Arrays.copyOfRange(inputL.toArray(new Integer[inputL.size()]), 0, last);

    System.out.println(Arrays.deepToString(inputA));

输出:

   [1, 1]

相关方法apidoc(全静态):