java - java中的升序和降序数字顺序

标签 java

我在 java 中执行升序和降序订单号,这是我的代码:

System.out.print("Enter How Many Inputs: ");
int num1 = Integer.parseInt(in.readLine());
int arr[] = new int[num1];

for (int i = 0; i<num1; i++) {
    System.out.print("Enter Value #" + (i + 1) + ":");
    arr[i] =Integer.parseInt(in.readLine());
}

System.out.print("Numbers in Ascending Order:" );

for(int i = 0; i < arr.length; i++) {
    Arrays.sort(arr);
    System.out.print( " " +arr[i]);
}

System.out.println(" ");
System.out.print("Numbers in Descending Order: " );

目前,代码生成以下内容:

Enter How Many Inputs: 5
Enter Value #1:3
Enter Value #2:5
Enter Value #3:6
Enter Value #4:11
Enter Value #5:2
Numbers in Ascending Order: 2 3 5 6 11 
Numbers in Descending Order: 

因此,Arrays.sort(arr) 调用似乎有效 - 但我正在寻找一种类似的简单方法来提供降序排序,但在文档中找不到它。有什么想法吗?

最佳答案

我想到了三种可能的解决方案:

1。颠倒顺序:

//convert the arr to list first
Collections.reverse(listWithNumbers);
System.out.print("Numbers in Descending Order: " + listWithNumbers);

2。向后迭代并打印它:

Arrays.sort(arr);
System.out.print("Numbers in Descending Order: " );
for(int i = arr.length - 1; i >= 0; i--){
  System.out.print( " " +arr[i]);
}

3。用“相反”比较器对其进行排序:

Arrays.sort(arr, new Comparator<Integer>(){
   int compare(Integer i1, Integer i2) {
      return i2 - i1;
   }
});
// or Collections.reverseOrder(), could be used instead
System.out.print("Numbers in Descending Order: " );
for(int i = 0; i < arr.length; i++){
  System.out.print( " " +arr[i]);
}

关于java - java中的升序和降序数字顺序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12656753/

相关文章:

Java 和 SEO URL

java - 更新到 Java 8,Eclipse 启动失败

java - libjvm.so : cannot open shared object file: No such file or directory

java - mvn 测试期间 System.console() 在命令行中返回 null

java - BlueJ 将计算器小程序连接到两个类

java - 无法在其他方法中检索 HashMap 输入

java - 将 MySQL 连接到 java 应用程序 - VPS (ubuntu)

Java HashMap 哈希函数

java - 重复条目异常 : Spring Hibernate/JPA cascade save Many To One

Java MessageDigest 提供 31 位而不是 32 位