package ers; import java.util.Scanner; public class Main{ public static void main(String[] args) { Scanner sc = new Scanner(System.in); while(sc.hasNext()) { String[] str = sc.nextLine().split(" "); int len = str.length; int[] arr = new int[len]; for(int i = 0;i<len;i++) { arr[i] = Integer.valueOf(str[i]); } quickSort(arr, 0, len-1); //selectSort(arr); //选择排序 //bubbleSort(arr); //冒泡排序 //insertSort(arr); //插入排序 for (int i = 0; i < len;i++) { System.out.print(arr[i]+" "); } } } /*冒泡排序*/ public static void bubbleSort(int[] arr) { for (int i = 0; i < arr.length-1; i++) { for (int j = 0; j < arr.length-i-1; j++) { if(arr[j]>arr[j+1]) //每次排序将最大的排在最后 { int temp = arr[j+1]; arr[j+1] = arr[j]; arr[j] = temp; } } } } /*插入排序*/ public static void insertSort(int[] arr) { for (int i = 1; i < arr.length; i++) { int h = i; int t=arr[i]; //将当前需要被安排插入的元素保存起来,因为此元素为对比标准 while(h>0) { if(t>=arr[h-1]) break; else { arr[h] = arr[h-1]; h--; } } arr[h] = t; } } /*选择排序*/ public static void selectSort(int[] arr) { int n = arr.length; for (int i = 0; i < n; i++) { int minIndex = i; for (int j = i + 1; j < n; j++) { if (arr[minIndex] > arr[j]) { minIndex = j; } } if (i != minIndex) { int temp = arr[i]; arr[i] = arr[minIndex]; arr[minIndex] = temp; } } } /*快排的固定切分方式*/ public static int partition(int []array,int lo,int hi){ //固定的切分方式 int key=array[lo]; while(lo<hi){ while(array[hi]>=key&&hi>lo){//从后半部分向前扫描 hi--; } array[lo]=array[hi]; while(array[lo]<=key&&hi>lo){//从前半部分向后扫描 lo++; } array[hi]=array[lo]; } array[hi]=key; return hi; } /*快速排序*/ public static void quickSort(int[] array,int lo ,int hi){ if(lo>=hi){ return ; } int index=partition(array,lo,hi); quickSort(array,lo,index-1); quickSort(array,index+1,hi); } }