算法研究学习一


(1)插入排序

      插入排序是逐个处理待排序的记录,每个新记录与前面已排序的子序列进行比较,将它插入到子序列中正确的位置 ,如下图所示。

c语言实现代码:

View Code

c#语言实现代码

View Code

 (2)冒泡排序

       

C语言实现代码:

View Code

C#实现代码:

View Code

 (3)选择排序

      选择排序第i次是选择数组中第i小的元素,并将该记录放到数组的第i个位置。换句话说,首先从未排序的序列中找到最小关键码,接着是次小的,依次类推,独特之处是很少交换。选择排序和冒泡排序比较相似,区别在于冒泡排序找到的最小元素是通过不断的交换相邻位置的值得到的,而选择排序只是先找到最新元素的位置,相当于数组的下标,然后最后一次交换。

C语言代码:

View Code

C#代码:

View Code

以上三种排序算法的平均时间复杂度均为:o(n*n),关键的瓶颈在于只比较相邻的元素;因此比较和移动只能一步步进行(选择排序除外)

 (4)二叉排序树     

      二叉排序树的特点:树中的任何一个节点,设其值关键码值为K,则该节点的左子树中任意一个节点的值都小于K;该节点右子树中任意一个节点的值都大于或等于K。如下图一个简单的二叉排序树所示:

根据二叉排序树的特点可知,中序遍历(左孩子-根节点-右孩子),可得到一个从小到大排好顺序的序列。查找某一个关键码为K的节点拥有折半查找的效率平均时间复杂度为:logn,二叉查找树中最关键的部分就是如何构造一个二叉排序树。下面代码实现一个二叉排序树的构造

 C代码如下:

View Code

【数据结构】常见排序算法复杂度

 

相关概念

1、稳定排序(stable sort)和非稳定排序

稳定排序是指所有相等的数经过某种排序算法操作后仍然能保持它们在排序之前的相对次序。反之就是非稳定排序。

2、内排序(internal sorting)和外排序(external sorting)

在排序过程中,所有需要排序的数都在内存,并在内存中调整它们的存储顺序,称为内排序;在排序过程中,只有部分数被调入内存,并借助内存调整数在外存中的存放顺序排序方法称为外排序。

排序算法

【冒泡排序】(Bubble Sort)

冒泡排序方法是最简单的排序方法。这种方法的基本思想是,将待排序的元素看作是竖着排列的“气泡”,较小的元素比较轻,从而要往上浮。在冒泡排序算法中我们要对这个“气泡”序列处理若干遍。所谓一遍处理,就是自底向上检查一遍这个序列,并时刻注意两个相邻的元素的顺序是否正确。如果发现两个相邻元素的顺序不对,即“轻”的元素在下面,就交换它们的位置。显然,处理一遍之后,“最轻”的元素就浮到了最高位置;处理二遍之后,“次轻”的元素就浮到了次高位置。在作第二遍处理时,由于最高位置上的元素已是“最轻”元素,所以不必检查。一般地,第i遍处理时,不必检查第i高位置以上的元素,因为经过前面i-1遍的处理,它们已正确地排好序。 

冒泡排序是稳定的。算法时间复杂度是O(n2)。 

 

【选择排序】(Selection Sort)

选择排序的基本思想是对待排序的记录序列进行n-1遍的处理,第 i 遍处理是将[i..n]中最小者与位置 i 交换位置。这样,经过 i 遍处理之后,前 i 个记录的位置已经是正确的了。 

选择排序是不稳定的。算法复杂度是O(n2 )。 

 

【插入排序】(Insertion Sort)

插入排序的基本思想是,经过i-1遍处理后,L[1..i-1]己排好序。第i遍处理仅将L插入L[1..i-1]的适当位置,使得L[1..i]又是排好序的序列。要达到这个目的,我们可以用顺序比较的方法。首先比较L和L[i-1],如果L[i-1]≤ L,则L[1..i]已排好序,第i遍处理就结束了;否则交换L与L[i-1]的位置,继续比较L[i-1]和L[i-2],直到找到某一个位置j(1≤j≤i-1),使得L[j] ≤L[j+1]时为止。

直接插入排序是稳定的。算法时间复杂度是O(n2) 

 

【堆排序】(Heap Sort)

堆排序是一种树形选择排序,在排序过程中,将A[n]看成是完全二叉树的顺序存储结构,利用完全二叉树中双亲结点和孩子结点之间的内在关系来选择最小的元素。 

堆排序是不稳定的。算法时间复杂度O(nlog2n)。 

 

【归并排序】(Merge Sort)

归并(Merge)排序法是将两个(或两个以上)有序表合并成一个新的有序表,即把待排序序列分为若干个子序列,每个子序列是有序的。然后再把有序子序列合并为整体有序序列。

归并排序是稳定的。其时间复杂度无论是在最好情况下还是在最坏情况下均是O(nlog2n)。 

 

【快速排序】(Quick Sort)

快速排序是对冒泡排序的一种本质改进。它的基本思想是通过一趟扫描后,使得排序序列的长度能大幅度地减少。在冒泡排序中,一次扫描只能确保最大数值的数移到正确位置,而待排序序列的长度可能只减少1。快速排序通过一趟扫描,就能确保某个数(以它为基准点吧)的左边各数都比它小,右边各数都比它大。然后又用同样的方法处理它左右两边的数,直到基准点的左右只有一个元素为止。 

快速排序是不稳定的。最理想情况算法时间复杂度O(nlog2n),最坏O(n ^2)。

 

各排序方法对比

 

冒泡排序算法时间复杂度是O(n^2)

选择排序算法时间复杂度是O(n^2)

插入排序算法时间复杂度是O(n^2)

快速排序是不稳定的。最理想情况算法时间复杂度O(nlog2n),最坏O(n^2)。

堆排序算法时间复杂度是O(nlogn)

归并排序算法时间复杂度是O(nlogn)

 

http://apps.hi.baidu.com/share/detail/59156739

 
标签: 数据结构
原文地址:https://www.cnblogs.com/Leo_wl/p/2478594.html