插入排序
1. 插入排序 时间复杂度:O(N^2)
2. 核心思想:使用1角标对应的元素和0角标进行比较,如果前面元素大,向右移动,确定角标1对应的元素的位置,再次使用2角标对应的元素依次和1和0都元素比较 依次这样比较…
3.插入排序图解
4.代码实现
public class InsertSortTest {
public static void main(String[] args) {
Integer[] arr = {34,8,64,51,32,21} ;
System.out.println("排序前:");
printArr(arr);
insertSort(arr) ;
System.out.println("排序后:");
printArr(arr);
}
private static void insertSort(Integer[] arr) {
int j ;
for(int p = 1 ; p < arr.length ; p ++ ){
Integer temp = arr[p] ;
for(j = p ; j>0 && temp.compareTo(arr[j-1])<0; j--){
arr[j] = arr[j-1] ;
}
arr[j] = temp ;
}
}
public static void printArr(Integer[] arr){
System.out.print("[");
for(int x = 0 ; x < arr.length ; x ++){
if(x == arr.length -1){
System.out.println(arr[x] +"]");
}else{
System.out.print(arr[x]+", ");
}
}
}
}
5.运行截图
|