(带哨兵)直接插入排序
来源:互联网 发布:js保存cookie到本地 编辑:程序博客网 时间:2024/05/01 22:55
基本思想:
将一个记录插入到已排序好的有序表中,从而得到一个新,记录数增1的有序表。即:先将序列的第1个记录看成是一个有序的子序列,然后从第2个记录逐个进行插入,直至整个序列有序为止。
要点:设立哨兵,作为临时存储和判断数组边界之用。
哨兵有两个作用:
① 进人查找(插入位置)循环之前,它保存了R[i]的副本,使不致于因记录后移而丢失R[i]的内容;
② 它的主要作用是:在查找循环中监视下标变量j是否越界。一旦越界(即j=0),因为R[0].可以和自己比较,循环判定条件不成立使得查找循环结束,从而避免了在该循环内的每一次均要检测j是否越界(即省略了循环判定条件j>=1)。
注意:
① 实际上,一切为简化边界条件而引入的附加结点(元素)均可称为哨兵。
【例】单链表中的头结点实际上是一个哨兵
② 引入哨兵后使得测试查找循环条件的时间大约减少了一半,所以对于记录数较大的文件节约的时间就相当可观。对于类似于排序这样使用频率非常高的算法,要尽可能地减少其运行时间。所以不能把上述算法中的哨兵视为雕虫小技,而应该深刻理解并掌握这种技巧。
public static void main(String[] args) {// TODO Auto-generated method stubint a[]={3,5,2,9,7,1,4};int n=a.length;for(int i=1;i<n;i++){if(a[i]<a[i-1]){//插入元素大于前一个元素则直接插入;否则查找插入元素的位置int j=i-1;int x=a[i];//哨兵a[i]=a[i-1];//先向后移动元素while(j>=0&&x<a[j]){a[j+1]=a[j];//向后移动元素j--;}a[j+1]=x;}}for(int i=0;i<n;i++){System.out.println(a[i]);}}
如果碰见一个和插入元素相等的,那么插入元素把想插入的元素放在相等元素的后面。所以,相等元素的前后顺序没有改变,从原无序序列出去的顺序就是排好序后的顺序,所以插入排序是稳定的。时间复杂度:O(n^2).
参考资料:
http://blog.csdn.net/hguisu/article/details/7776068
http://blog.csdn.net/q451792269/article/details/53445291
0 0
- (带哨兵)直接插入排序
- 带哨兵的直接插入排序法
- 直接插入排序(哨兵和越界)
- 带哨兵的插入排序
- 八种排序算法Java实现-直接插入和带哨兵的插入排序
- 带哨兵与不带哨兵的插入排序
- 【数据结构】直接插入排序_哨兵位
- 直接插入排序的哨兵的作用
- 直接插入排序算法-设置哨兵版
- 直接插入排序 解释哨兵的好例子
- 直接插入排序算法-不设置哨兵版
- 十二.C语言8种排序算法及其实现 1.希尔排序 2.二分插入法 3.直接插入法 4.带哨兵的直接排序法 5.冒泡排序 6.选择排序 7.快速排序 8.堆排序
- C语言8种排序算法及其实现 1.希尔排序 2.二分插入法 3.直接插入法 4.带哨兵的直接排序法 5.冒泡排序 6.选择排序 7.快速排序 8.堆排序
- 排序(直接插入排序)
- 插入排序一(直接插入排序)
- 算法---插入排序(直接插入排序)
- 插入排序(希尔排序、直接插入、折半插入排序)
- 数据结构-插入排序(直接插入排序+折半插入排序)
- vxworks错误码解读
- ubantu 配置jdk tomcat xshell连接
- CodeForces798C Mike and gcd problem(思路)
- 排序模板:分数线划定
- Android Studio快速注释
- (带哨兵)直接插入排序
- Android studio (单元测试)
- json数据结构拼装的一个例子
- 交通流
- 为何要在GLSL中使用UBO
- NIO学习整理
- Codeforces Round #408 (Div. 2)-D. Police Stations
- Java泛型
- Django+Vue.js 初学入手的一些坑,已填坑