算法初识---希尔排序

简介: 希尔排序是插入排序的优化版本,具体做法是: 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

目录
相关文章
|
20天前
|
算法 搜索推荐 Java
数据结构与算法(Java篇)笔记--希尔排序
数据结构与算法(Java篇)笔记--希尔排序
|
7月前
|
算法 搜索推荐 Shell
Python算法——希尔排序
Python算法——希尔排序
40 0
|
20天前
|
算法 前端开发 搜索推荐
前端算法之希尔排序
前端算法之希尔排序
4 0
|
20天前
|
搜索推荐 算法 Java
sort-06-shell sort 希尔排序算法详解
这是一个关于排序算法的系列文章摘要。文章汇总了各种排序算法,包括冒泡排序、快速排序、选择排序、堆排序、插入排序、希尔排序、归并排序、计数排序、桶排序以及大文件外部排序。特别地,希尔排序是一种改进的插入排序,通过使用不同的步长对元素进行分组排序,以提高效率。算法最终以较小的步长进行排序,接近线性时间复杂度。文章还提供了Java代码实现,并举例说明了希尔排序的过程。所有内容可在开源项目[https://github.com/houbb/sort](https://github.com/houbb/sort)中找到。
|
20天前
|
人工智能 搜索推荐 Shell
【排序算法】插入排序与希尔排序,你不想知道为什么希尔比插入更快吗?
【排序算法】插入排序与希尔排序,你不想知道为什么希尔比插入更快吗?
|
20天前
|
搜索推荐 算法 Shell
【数据结构与算法】直接插入排序和希尔排序
【数据结构与算法】直接插入排序和希尔排序
|
20天前
|
搜索推荐 测试技术
【排序算法】希尔排序
【排序算法】希尔排序
|
20天前
|
搜索推荐 算法 Shell
【数据结构】八大排序之希尔排序算法
【数据结构】八大排序之希尔排序算法
26 0
|
20天前
|
搜索推荐 算法
【排序算法】一文教你从零学会希尔排序
【排序算法】一文教你从零学会希尔排序
|
20天前
|
存储 算法 搜索推荐
【数据结构与算法】:插入排序与希尔排序
欢迎大家来到初阶数据结构的最后一小节:排序
【数据结构与算法】:插入排序与希尔排序