直接插入排序
2014-03-19 15:14
183 查看
核心思想
每次从无序表中取出第一个元素,把它插入到有序表的合适位置,使有序表仍然有序。
将待插入记录R[i]的关键字从右向左依次与有序区中记录R[j](j=i-1,i-2,…,1)的关键字进行比较:
① 若R[j]的关键字大于R[i]的关键字,则将R[j]后移一个位置;
②若R[j]的关键字小于或等于R[i]的关键字,则查找过程结束,j+1即为R[i]的插入位置。
关键字比R[i]的关键字大的记录均已后移,所以j+1的位置已经腾空,只要将R[i]直接插入此位置即可完成一趟直接插入排序。
算法特点
稳定排序
最坏时间复杂度O(n^2)
空间复杂度O(1)
每次从无序表中取出第一个元素,把它插入到有序表的合适位置,使有序表仍然有序。
将待插入记录R[i]的关键字从右向左依次与有序区中记录R[j](j=i-1,i-2,…,1)的关键字进行比较:
① 若R[j]的关键字大于R[i]的关键字,则将R[j]后移一个位置;
②若R[j]的关键字小于或等于R[i]的关键字,则查找过程结束,j+1即为R[i]的插入位置。
关键字比R[i]的关键字大的记录均已后移,所以j+1的位置已经腾空,只要将R[i]直接插入此位置即可完成一趟直接插入排序。
算法特点
稳定排序
最坏时间复杂度O(n^2)
空间复杂度O(1)
#include <stdio.h> void insertSort(int array[], int length) { int i, j; int key; for(i=1; i<length; i++) { key = array[i]; j= i-1; while(j>=0 && array[j]>key) { array[j+1] = array[j]; j--; } array[j+1] = key; } } int main() { int nums[10] = {1,4,2,6,3,8,7,0,9,5}; int i; insertSort(nums, 10); for(i=0; i<10; i++) { printf("%d ", nums[i]); } return 0; }
相关文章推荐
- 面试复习(C++)之直接插入排序
- C++模板实现直接插入排序
- 直接插入排序的C实现
- 直接插入排序
- 排序算法之直接插入排序、二分插入排序和希尔排序
- C# 直接插入排序方法
- 排序算法(堆排序,归并排序,快速排序、选择排序、直接插入排序)
- 直接插入排序
- 直接插入排序
- 直接插入排序
- 排序算法之1)直接插入排序
- 直接插入排序(Insertion Sort)
- 直接插入排序算法 C语言版
- 直接插入排序和冒泡排序C实现
- 排序之直接插入排序(Straight Insertion Sort)
- 必须会的排序算法---(1)直接插入排序
- Java 直接插入排序的三种实现
- Java程序实现冒泡排序、直接排序、插入排序方法
- 插入排序(直接插入排序和希尔排序)
- 直接插入排序