查看所有50道基础算法题请看:
Java的50道基础算法题
package Demo28Sort;
import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.Scanner;
public class Sort2 {
/**
* 对10个数进行排序。
*/
/*
分析:为了让用户能够一下子输入十个数字,我们可以让他输入字符串,用逗号隔开,完了再split分割成数组
为了能更加灵活的排序,即降序和逆序排序,可以使用集合的Sort方法中的comparator来实现
*/
public static void main(String[] args) {
// 获取用户输入10个数字
Scanner sc = new Scanner(System.in);
System.out.println("请您输入10个数字,以(英文)逗号隔开...");
String numbers = sc.next();
// 把用户输入的字符串形式的10个数字解析为一个字符串数组
String[] num = numbers.split(",");
ArrayList<Integer> list = new ArrayList<>();
// 判断如果用户输入的格式正确,且数字数量足够,则把数字都添加到一个ArrayList集合中
if(num.length==10){
for (String s : num) {
Integer n = Integer.valueOf(s);
list.add(n);
}
// 让用户选择排序方式:降序还是升序?
System.out.println("请问您是要升序还是降序啊?升序输入:up/UP,降序输入:down/DOWN");
String sorts = sc.next().toLowerCase();
if(sorts.equals("up")){
// 使用Collections.sort()方法对list集合进行排序,默认为升序
Collections.sort(list);
System.out.println("您输入的10个数字经过升序排列后的结果如下:");
System.out.println(list);
System.out.println("===================================");
}else if(sorts.equals("down")){
// 对list集合进行降序排序,这里使用了Lambda表达式
Collections.sort(list,(Integer o1, Integer o2)->{
return o2-o1;
});
System.out.println("您输入的10个数字经过降序排列后的结果如下:");
System.out.println(list);
System.out.println("====================================");
}else{
System.out.println("您输入的排序方法暂不支持,请输入升序输入:up/UP,降序输入:down/DOWN");
}
}else{
System.out.println("您输入的不是十个数字,或者输入的格式有误,请重新输入...");
}
// 将集合清空,以防用户手贱
list.clear();
}
}