算法初识---希尔排序

简介: 希尔排序是插入排序的优化版本,具体做法是: 1)选定一个增长量h,按照增长量对数据进行分组。 2)对分好组的每一组数据再进行插入排序。 3)减小增长量h,最小减为1,重复2)步骤,即继续对分组数据进行插入排序。

一、算法内容

        希尔排序是插入排序的优化版本,具体做法是:


        1)选定一个增长量h,按照增长量对数据进行分组。


        2)对分好组的每一组数据再进行插入排序。


        3)减小增长量h,最小减为1,重复2)步骤,即继续对分组数据进行插入排序。


二、代码实现

#include <iostream>

using namespace std;

int main()

{  int arr[8]={1,5,9,3,2,4,7,10};

  for(int i=0;i<8;i++)

   cout<<arr[i]<<' ';

cout<<endl;

  int h=1;

  while(h<8/2)//求增长量h的方法

  {

   h=2*h+1;

  }

  int temp;

   while(h>=1)

   {  for(int i=h;i<8;i+=h)

     {

      for(int j=i-h;j>=0;j-=h)

      {

       if(arr[j]<arr[j-h])

       {  temp=arr[j];

          arr[j]=arr[j-h];

          arr[j-h]=temp;

    }

  else

    break;

   }

  }

 

    h/=2;   //h减小的原则

}

for(int i=0;i<8;i++)

   cout<<arr[i]<<' ';

 return 0;

}

截屏2023-04-23 20.25.17.png

目录
相关文章
|
6月前
|
算法 搜索推荐 Java
数据结构与算法(Java篇)笔记--希尔排序
数据结构与算法(Java篇)笔记--希尔排序
|
20天前
|
算法 搜索推荐 Shell
数据结构与算法学习十二:希尔排序、快速排序(递归、好理解)、归并排序(递归、难理解)
这篇文章介绍了希尔排序、快速排序和归并排序三种排序算法的基本概念、实现思路、代码实现及其测试结果。
14 1
|
5月前
|
算法 搜索推荐
数据结构算法--6 希尔排序和计数排序
**希尔排序**是插入排序的改进版,通过分组插入来提高效率。它逐步减少元素间的间隔(增量序列),每次对每个间隔内的元素进行插入排序,最终增量为1时进行最后一次直接插入排序,实现整体接近有序到完全有序的过程。例如,对数组`5, 7, 4, 6, 3, 1, 2, 9, 8`,先以间隔`d=4`排序,然后`d=2`,最后`d=1`,完成排序。计数排序则适用于0到100的数值,通过统计每个数出现次数,创建对应计数数组,再根据计数重建有序数组,时间复杂度为`O(n)`。
|
4月前
|
算法 搜索推荐 Shell
|
5月前
|
人工智能 搜索推荐 JavaScript
心得经验总结:排序算法:插入排序法(直接插入法和希尔排序法)
心得经验总结:排序算法:插入排序法(直接插入法和希尔排序法)
32 0
|
5月前
|
机器学习/深度学习 搜索推荐 算法
【C/排序算法】:直接插入排序和希尔排序
【C/排序算法】:直接插入排序和希尔排序
42 0
|
5月前
|
搜索推荐
排序算法---希尔排序---详解&&代码
排序算法---希尔排序---详解&&代码
|
5月前
|
算法 Shell C语言
数据结构与算法——希尔排序(引例、希尔增量序列、原始希尔排序、代码、时间复杂度、Hibbard增量序列、Sedgewick增量序列)
数据结构与算法——希尔排序(引例、希尔增量序列、原始希尔排序、代码、时间复杂度、Hibbard增量序列、Sedgewick增量序列)
51 0
|
6月前
|
存储 算法 搜索推荐
【数据结构与算法】:插入排序与希尔排序
欢迎大家来到初阶数据结构的最后一小节:排序
【数据结构与算法】:插入排序与希尔排序
|
6月前
|
搜索推荐 算法 Shell
【数据结构与算法】直接插入排序和希尔排序
【数据结构与算法】直接插入排序和希尔排序