广告
返回顶部
首页 > 资讯 > 后端开发 > 其他教程 >C++如何实现希尔排序算法
  • 686
分享到

C++如何实现希尔排序算法

2023-06-26 03:06:14 686人浏览 八月长安
摘要

这篇“c++如何实现希尔排序算法”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“C++如何实现希尔排序算法”文章吧。1.代码模

这篇“c++如何实现希尔排序算法”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“C++如何实现希尔排序算法”文章吧。

1.代码模板

// 希尔排序(shell Sort)void ShellSort(sqlist *L){    int i, j;    int increment = L->length;  // 先让增量初始化为序列的长度    do {        increment = increment / 3 + 1;   // 计算增量的值        for (i = increment + 1; i <= L->length; i ++ ) {             if (L->arr[i] < L->arr[i - increment]) {   // 如果L->[i]需要插入有序增量子表                L->arr[0] = L->arr[i];   // 暂存在哨兵位                for (j = i - increment; j > 0 && L->arr[0] < L->arr[j]; j -= increment) {  // 遍历增量子表,寻找插入位置                    L->arr[j + increment] = L->arr[j];                }                L->arr[j+increment] = L->arr[0];  // 插入            }        }    } while (increment > 1);}

2.算法介绍

希尔排序,又叫缩小增量排序,算法属于插入类排序的进阶算法,采取跳跃分割的策略,将关键字较小的元素跳跃式的往前挪,大大减小了交换比较的次数。使得序列整体基本有序 ,即大的元素基本在后面,小的元素基本在前面,不大不小的元素基本在中间。

希尔排序的关键在于将序列中相隔某个“增量”的元素组成一个子序列,且序列的最后一个增量必须为1,这样才能保证最后的结果是有序且正确的。但增量如何选择为最佳,至今仍无定论。且由于元素是跳跃式移动的,所有希尔排序是一个不稳定的排序算法,其时间复杂度受到增量选择的影响,最好为O(n^1.3) , 最坏为O(n*n)。

3.实例

#include <iOStream>using namespace std;const int N = 100;typedef struct{    int arr[N];    // 存储待排序的序列    int length;    // 存储序列的长度} SqList;void ShellSort(SqList *L){    int i, j;    int increment = L->length;    do {        increment = increment / 3 + 1;        for (i = increment + 1; i <= L->length; i ++ ) {            if (L->arr[i] < L->arr[i - increment]) {                L->arr[0] = L->arr[i];                for (j = i - increment; j > 0 && L->arr[0] < L->arr[j]; j -= increment)                    L->arr[j + increment] = L->arr[j];                L->arr[j + increment] = L->arr[0];            }        }    } while (increment > 1);}int main(){    SqList L;    L.arr[1] = 50;    L.arr[2] = 10;    L.arr[3] = 90;    L.arr[4] = 30;    L.arr[5] = 70;    L.arr[6] = 40;    L.arr[7] = 80;    L.arr[8] = 60;    L.arr[9] = 20;    L.length = 9;    ShellSort(&L);    for (int i = 1; i <= L.length; i ++ )        cout << L.arr[i] << " ";}

以上就是关于“C++如何实现希尔排序算法”这篇文章的内容,相信大家都有了一定的了解,希望小编分享的内容对大家有帮助,若想了解更多相关的知识内容,请关注编程网其他教程频道。

--结束END--

本文标题: C++如何实现希尔排序算法

本文链接: https://www.lsjlt.com/news/306623.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • C++如何实现希尔排序算法
    这篇“C++如何实现希尔排序算法”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“C++如何实现希尔排序算法”文章吧。1.代码模...
    99+
    2023-06-26
  • C++实现希尔排序算法实例
    目录1.代码模板2.算法介绍3.实例1.代码模板 // 希尔排序(Shell Sort) void ShellSort(SqList *L) { int i, j; ...
    99+
    2022-11-12
  • c++实现排序算法之希尔排序方式
    目录排序算法之希尔排序基本思想希尔排序算法复杂度分析关于希尔排序的问题分析排序算法之希尔排序及时间复杂度分析希尔排序时间复杂度排序算法之希尔排序 基本思想 将相距某个“增...
    99+
    2022-11-13
  • C#实现希尔排序
    对于大规模乱序的数组,插入排序很慢,因为它只会交换相邻的元素,因此元素只能一点一点地从数组地一段移动到另一端。希尔排序改进了插入排序,交换不相邻地元素以对数组地局部进行排序,最终用插...
    99+
    2022-11-13
  • C#如何实现希尔排序
    本篇内容主要讲解“C#如何实现希尔排序”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“C#如何实现希尔排序”吧!对于大规模乱序的数组,插入排序很慢,因为它只会交换相邻的元素,因此元素只能一点一点地...
    99+
    2023-06-30
  • python排序算法之希尔排序
    目录一、前言二、算法描述第一步:第二步:第三步:第四步:第五步:三、代码实现一、前言 相关知识来自《python算法设计与分析》。初级排序算法是指几种较为基础且容易理解的排序算法。初...
    99+
    2023-05-17
    python排序算法 python希尔排序
  • 图解排序算法之希尔排序Java实现
    目录一、基本思想二、代码实现三、总结一、基本思想 希尔排序是把记录按下标的一定增量分组,对每组使用直接插入排序算法排序;随着增量逐渐减少,每组包含的关键词越来越多,当增量减至1时,整...
    99+
    2022-11-12
  • java 排序算法之希尔算法
    目录插入排序存在的问题简单介绍基本思想代码实现大数据量耗时测试移动法实现希尔排序移动法-大数据量耗时测试算法分析 注:学习本篇的前提是要会插入排序,数据结构与算法——排序算法-插入排...
    99+
    2022-11-12
  • 排序算法之希尔排序法解析
    目录什么是希尔排序法希尔排序法与插入排序法之间的区别与联系代码演示对比什么是希尔排序法 希尔排序法(Shell Sort),也称为缩小增量排序,是一种改进的插入排序算法。它通过将待排...
    99+
    2023-08-08
    希尔排序算法 希尔排序法
  • C++深入浅出讲解希尔排序算法的实现
    目录希尔排序1.基本思想预排序2.算法实现3.时间复杂度插入排序分为两种:直接插入排序&希尔排序 希尔排序 1.基本思想 希尔排序是在直接插入排序基础上的优化,属于非常牛掰的...
    99+
    2022-11-13
  • 图解Java排序算法之希尔排序
    目录基本思想代码实现总结希尔排序是希尔(Donald Shell)于1959年提出的一种排序算法。希尔排序也是一种插入排序,它是简单插入排序经过改进之后的一个更高效的版本,也称为缩小...
    99+
    2022-11-12
  • 排序算法图解之Java希尔排序
    目录1.希尔排序简介2.希尔排序算法图解3.希尔排序代码实现1.希尔排序简介 希尔排序是希尔(Donald Shell)于1959年提出的一种排序算法,其也是一种特殊的插入排序,即将...
    99+
    2022-11-13
    Java 希尔排序 Java 排序算法 Java 排序
  • 分析Java排序算法之希尔排序
    这篇文章主要介绍“分析Java排序算法之希尔排序”,在日常操作中,相信很多人在分析Java排序算法之希尔排序问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”分析Java排序算法之希尔排序”的疑惑有所帮助!接下来...
    99+
    2023-06-25
  • Java 十大排序算法之希尔排序刨析
    目录希尔排序原理希尔排序的API设计希尔排序的代码实现希尔排序是插入排序的一种,又称"缩小增量排序”,是插入排序算法的一种更高效的改进版本。 希尔排序原理 1.选定一个增长量h,按照...
    99+
    2022-11-12
  • JAVA十大排序算法之希尔排序详解
    目录希尔排序代码实现时间复杂度算法稳定性总结希尔排序 一种基于插入排序的快速的排序算法。简单插入排序对于大规模乱序数组很慢,因为元素只能一点一点地从数组的一端移动到另一端。例如,如果...
    99+
    2022-11-12
  • 怎么利用Java实现一个希尔排序算法
    这期内容当中小编将会给大家带来有关怎么利用Java实现一个希尔排序算法,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。Java 实现希尔排序Java代码    pub...
    99+
    2023-05-31
    java ava 希尔排序
  • 插入排序算法之希尔排序+直接插入排序
    目录希尔排序一、直接插入排序1. 单趟排序2. 直接插入排序二、希尔排序三、测试希尔排序和直接插入排序性能希尔排序 在介绍希尔排序之前,先了解一下直接插入排序 一、直接插入排序 1....
    99+
    2022-11-12
  • Java 选择排序、插入排序、希尔算法实例详解
           1、基本思想:在要排序的一组数中,选出最小的一个数与第一个位置的数交换;然后在剩下的数当中再找最小的与第二个位置的数交换,如此循环到倒数第二个数和最后一个数比较为止。...
    99+
    2023-05-31
    java 选择排序 插入排序
  • C语言常见排序算法之插入排序(直接插入排序,希尔排序)
    目录前言一、直接插入排序1.1 基本思想1.2 算法思想1.3 程序实现1.4 直接插入排序的总结二、希尔排序2.1 算法思想2.2 程序实现2.3 希尔排序的特征总结前言...
    99+
    2022-11-13
  • Java希尔排序怎么实现
    这篇文章主要讲解了“Java希尔排序怎么实现”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Java希尔排序怎么实现”吧!希尔排序(shell sort)是插入排序的一种,它是简单插入排序经过...
    99+
    2023-06-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作