许久没有写点东西了,答辩以后人也变得松懈。今天看到简书又有人点赞以前记录的冒泡排序,点进去一看,竟然有4w+的阅读量,心生疑问,咋会有这么高的阅读量,打开百度搜索冒泡排序,结果第3条就是个人。点开认真看了看,其实写得很差,还改了两个错别字(狗头),这个阅读量或许只是记录的点击量。但我萌生一个想法,趁如今有时间,想把排序系列作完,便于之后本身回顾。java
排序—冒泡排序
排序—选择排序
排序—快速排序
排序—插入排序
排序-希尔排序(待完善)
排序—归并排序(待完善)
排序—基数排序(待完善)
排序—堆排序(待完善)
排序—桶排序(待完善)
排序—计数排序(待完善)
排序—排序算法总结(待完善)算法
基本思想是在一个有序的序列
中找到待排序元素的位置,好比将3
插入-1,2,4,6
这个有序序列中,先与6和4比较,直到和2比较以后,找到适合插入的位置(2以后)。
下面以按升序排序为例:code
动图展现(图片来源见参考资料)
blog
/** * 插入排序 * @param arr */ public static void insertSort(int[] arr) { if(arr == null || arr.length == 0) return; int curEle, preIndex; // 记录当前待排序元素和前一个元素的下标 for(int i = 0; i < arr.length; i++) { preIndex = i - 1; curEle = arr[i]; while(preIndex >=0 && arr[preIndex] > curEle){ arr[preIndex + 1] = arr[preIndex]; // 移动元素 preIndex--; } // 将待排序元素插入新的位置 arr[preIndex + 1] = curEle; } }
时间复杂度:$O(n^2)$
空间复杂度:$O(1)$
稳定性:稳定排序
本文如有不当,请指出。
此致,敬礼!get