簡體   English   中英

刪除數組的最高值和最低值

[英]Delete the highest and lowest value of an Array

我正在嘗試刪除數組int[] ary4 = {2,17,10,9,16,3,9,16,5,1,17,14}; 它適用於這個特定的,但是當我改變數字時,它並沒有按照我的意圖進行。 我知道如何以不同的方式做到這一點,但我想用這種方法解決它。

public static int[] elimAll(int[] a) {
        int c = 1;
        int g = 1;
        int[] b = a.clone();
        Arrays.sort(b);

        for (int i = 0; i < b.length; i++){

            if (i == 0) {
                if (b[i] < b[c]) {
                    b[i] = 0;
                    c++;
                }else{
                    if (b[i] < b[c] && b[i] < b[i-1]) {
                        b[i] = 0;
                        c++;
                    }
                }
            }
        }

        for (int i = 0; i < b.length; i++){
            if (i == b.length-1 || i == b.length-2){
                if (b[i] >= b[b.length-1] || b[i] >= b[b.length-2]){
                    b[i] = 0;
                    g++;
                }
            }else {
                if (b[i] > b[i + 1]) {
                    b[i] = 0;
                    g++;
                }
            }
        }
        return b;
    }

這是一種方法。 它不需要任何排序。

int[] ary4 = {2,17,10,9,16,3,9,16,5,1,17,14};
System.out.println("Before: " + Arrays.toString(ary4));
int[] result = elimAll(ary4);
System.out.println(" After: " + Arrays.toString(result));

印刷品(您可以看到兩個 17 和一個單獨的 1 被刪除)

Before: [2, 17, 10, 9, 16, 3, 9, 16, 5, 1, 17, 14]
 After: [2, 10, 9, 16, 3, 9, 16, 5, 14]

解釋

  • 遍歷數組查找highest值和lowest值。
  • 再次迭代,測試每個值是最高值還是最低值。
  • 如果不是,則將值添加到新數組並增加索引。
  • 完成后,返回數組的副本,並刪除剩余的值。
public static int[] elimAll(int[] array) {
  
    int highest = Integer.MIN_VALUE;
    int lowest = Integer.MAX_VALUE;
    
    for (int val : array) {
        highest = Math.max(highest, val);
        lowest = Math.min(lowest,val);
    }
   
    int k = 0;
    
    int [] result = new int[array.length];     
    for(int val : array) {
        if (val != highest && val != lowest) {
            result[k++] = val;
        }
    }
    
    return Arrays.copyOf(result, k);
}

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM