排序算法
·
算法 | 概念原理 |
---|---|
选择排序 | 从数组中选择最小元素,将它与数组的第一个元素交换位置。再从数组剩下的元素中选择出最小的元素,将它与数组的第二个元素交换位置。不断进行这样的操作,直到将整个数组排序。 |
冒泡排序 | 从左到右不断交换相邻逆序的元素,在一轮的循环之后,可以让未排序的最大元素上浮到右侧。在一轮循环中,如果没有发生交换,那么说明数组已经是有序的,此时可以直接退出。 |
插入排序 | 每次都将当前元素插入到左侧已经排序的数组中,使得插入之后左侧数组依然有序。对于数组 {3, 5, 2, 4, 1},它具有以下逆序:(3, 2), (3, 1), (5, 2), (5, 4), (5, 1), (2, 1), (4, 1),插入排序每次只能交换相邻元素,令逆序数量减少 1,因此插入排序需要交换的次数为逆序数量。 |
希尔排序 | 希尔排序使用插入排序对间隔 h 的序列进行排序。通过不断减小 h,最后令 h=1,就可以使得整个数组是有序的。 |
快速排序 | 快速排序通过一个切分元素将数组分为两个子数组,左子数组小于等于切分元素,右子数组大于等于切分元素,将这两个子数组排序也就将整个数组排序了(取 a[l] 作为切分元素,然后从数组的左端向右扫描直到找到第一个大于等于它的元素,再从数组的右端向左扫描找到第一个小于它的元素,交换这两个元素。不断进行这个过程,就可以保证左指针 i 的左侧元素都不大于切分元素,右指针 j 的右侧元素都不小于切分元素。当两个指针相遇时,将切分元素 a[l] 和 a[j] 交换位置。) |
归并排序 | 归并排序的思想是将数组分成两部分,分别进行排序,然后归并起来 |
堆排序 | 把最大元素和当前堆中数组的最后一个元素交换位置,并且不删除它,那么就可以得到一个从尾到头的递减序列,从正向来看就是一个递增序列,这就是堆排序。(堆中某个节点的值总是大于等于其子节点的值,并且堆是一颗完全二叉树。堆可以用数组来表示,这是因为堆是完全二叉树,而完全二叉树很容易就存储在数组中。) |
排序:博客1
排序:博客2
排序:博客3
博客2中的希尔排序实现有问题,比如博客3中给的图解析的情况。博客2整体还是很不错的。
二叉树:博客1
二叉树:博客2
链表:博客1(特别好,针对java的讲解)
链表:博客2
链表:博客3
数据结构基本概念篇,一个学习导引吧