温馨提示:本文翻译自stackoverflow.com,查看原文请点击:java - Sorting list of numbers

java - 数字排序列表

发布于 2020-03-27 11:02:19

我正在尝试从最小到最大的数字列表进行排序并打印出来。我尝试了两件事:

1。

public class Sorter {
    public static void main(String[] args) {
        int[] numbers = {1, 3, 8, 2, 5, -2, 0, 7, 15};
        int[] sorted = new int[numbers.length];

        for (int a = 0; a < numbers.length; a++) {
            int check = 0;
            for (int b = 0; b < numbers.length; b++) {
                if (numbers[a] < numbers[b]) {
                    check++;
                }
            }
            sorted[check] = numbers[a];
        }

        for (int c = numbers.length - 1; c >= 0; c--) {
            System.out.print(sorted[c] + ", ");
        }
    }
}

这个东西可以用,但是不能使用重复的值,所以我尝试了另一件事

public class Sortertwo {
    public static void main(String[] args) {
        int[] numinput = {3, 2, 1, 4, 7, 3, 17, 5, 2, 2, -2, -4};
        int[] numsorted = new int[numinput.length];

        int n = 0;
        for (; n < numinput.length; ) {

            for (int b = 0; b < numinput.length; b++) {
                int check = 0;
                for (int c = 0; c < numinput.length; c++) {
                    if (numinput[b] <= numinput[c]) {
                        check++;
                    }
                }

                if (check >= (numinput.length - n) && numinput[b] != 0) {
                    numsorted[n] = numinput[b];
                    numinput[b] = 0;
                    n++;
                }

                if (n >= (numinput.length)) {
                    break;
                }
            }
        }

        for (int g = 0; g < numinput.length; g++) {
            System.out.print(numsorted[g] + ", ");
        }
    }
}

它所依赖的是,一旦使用了第一个数组中的数字(找到了最小的数字),则当程序下次遍历该数组时就必须忽略它。我想像null一样分配它,但是它不起作用,所以我将其分配为零,然后将其忽略,这是一个问题,因为列表中不能包含零。有什么更好的办法吗?谢谢。

查看更多

查看更多

提问者
Runciter
被浏览
79
Playturbo 2019-07-03 22:22

您可以随时使用:

Arrays.sort(numbers);