简单的排序

public class Sort {
public static void main(String[] args){
int[] arr = {1,0,9,8,2,5,6,7,4,3};
print(arr);
selectSort(arr);
System.out.println();
print(arr);
bubbleSort(arr);
System.out.println();
print(arr);
insertSort(arr);
System.out.println();
print(arr);
}


private static void print(int[] arr){
for(int i=0;i<arr.length;i++){
System.out.print(arr[i]+"\t");
}
}
//挨个交换,将最大的放在右边
public static void bubbleSort(int[] arr){
if(arr!=null&&arr.length>1){
int temp ;
for(int i=arr.length-1;i>1;i--){
for(int j=0;j<i;j++){
if(arr[j]>arr[j+1]){
temp = arr[j+1];
arr[j+1] = arr[j];
arr[j] = temp;
}
}
}
}
}

//选择最小的,与左边元素交换,将小的放在左边
public static void selectSort(int[] arr){
int min;
int temp;
if(arr!=null&&arr.length>1){
for(int i=0;i<arr.length-1;i++){
min = i;
for(int j=i+1;j<arr.length;j++){
if(arr[j]<arr[min]){
min = j;
}
}
temp = arr[i];
arr[i] = arr[min];
arr[min] = temp;
}
}
}
//选择一个左边有序,自己及自己右边无序的元素,如果左边的大于它,则向右移动,否则,插入这个元素
public static void insertSort(int[] arr){
if(arr!=null&&arr.length>1){
for(int i=1;i<arr.length;i++){
int temp = arr[i];
int index = i;
while(index>=0&&arr[index-1]>temp){
arr[index]=arr[index-1];
index--;
}
arr[index]= temp;
}
}
}

}

你可能感兴趣的:(J#)