zoukankan      html  css  js  c++  java
  • 数据结构概览之第八章排序

    前言:数据结构概览之第八章排序整理

      插入排序

    思想:

    从待排关键字序列中的第二个关键字开始一直到最后的一个关键字结束,不论待排序的关键字是否有序,都要执行 len -1 次排序;

    把当前的关键字currentElem用哨兵记录;

    比较哨兵和currentElem之前的关键字的大小,并且适当的进行后移的操作;

    到最后找到哨兵的位置,进行插入。

    代码如下:

     1 /**
     2  插入排序
     3 
     4  @param R 数组
     5  @param len 数组中元素个数
     6  */
     7 void insertSort(int R[],int len);
     8 
     9 void insertSort(int R[],int len){
    10     int i,j;
    11     int temp;
    12     for(i = 1;i < len;i ++){
    13         j = i - 1;
    14         temp = R[i];
    15         while (j >= 0 && temp < R[j]) {
    16             R[j+1] = R[j];
    17             --j;
    18         }
    19         R[j+1] = temp;
    20     }
    21 }
    View Code

    测试函数以及输出:

    1 int R[] = {1,2,-2,3,4,-3,0};
    2         insertSort(R, sizeof(R)/sizeof(int));
    3         for (int i = 0; i < 7; i ++) {
    4             printf("%d	",R[i]);
    5         }
    6 //        -3    -2    0    1    2    3    4    Program ended with exit code: 0
    View Code

    和课本不同之处:记得之前的课本上是用的一个"哨兵"来记录这个当前待排序的关键字,这里用temp的话原理是一样的;

    参考资料:

    数据结构高分笔记

    数据结构严蔚敏版配套PPT

    OS交流群欢迎你的加入!

    群二维码:

    先写到这么多

    如有问题,敬请指正;

    如需转载,请注明出处,谢谢!

    我会不定期分享 iOS 相关技术文章
  • 相关阅读:
    如何使用IntelliJ IDEA 14创建基于Maven3的Java Web Project
    一些python语法的合集
    thuwc2019滚粗记
    noip2018总结
    树链剖分
    NOIp2017游记(滚粗之旅)
    使用Redux管理你的React应用
    校招面试中积累的前端问题
    WebService 生成类的命令语句
    Request 请求页面的地址路径获取
  • 原文地址:https://www.cnblogs.com/ITCoderW/p/8006302.html
Copyright © 2011-2022 走看看