当前位置: 首页 > news >正文

排序--希尔排序

希尔排序介绍

希尔排序核心思想就是:1,分组;2,直接插入排序:越有序越快
希尔排序就是多次利用直接插入排序的一个排序算法.
希尔排序的算法思想:间隔式分组,利用直接插入排序让组内有序,然后缩小分组再次排序,直到组数为1希尔排序的理论基础就是直接插入排序越有序越快;
希尔排序示意图:
在这里插入图片描述

完整代码

//一趟希尔排序,gap为组数(间隔)
static  void  Shell(int* arr, int len, int gap)
{int  tmp;int j;for (int i = gap; i < len; i++){tmp = arr[i];for (j = i - gap; j >= 0; j -= gap){if (arr[j] > tmp){arr[j + gap] = arr[j];}else  {break;  }}arr[j + gap] = tmp;  }
}void  ShellSort(int* arr, int len)  
{int d[] = { 5,3,1 };//分组数,最后一个一定为1  for (int i = 0; i < sizeof(d) / sizeof(d[0]); i++)  {Shell(arr, len, d[i]);//一趟希尔排序  }
}

本篇完!🍗

http://www.lryc.cn/news/449913.html

相关文章:

  • 【教程】57帧! Mac电脑流畅运行黑神话悟空
  • 『大模型笔记』Docker如何清理Build Cache!
  • 如何使用 Python 读取数据量庞大的 excel 文件
  • c语言200例 067
  • RabbitMQ的高级特性-死信队列
  • Python 复制PDF中的页面
  • Sql Developer日期显示格式设置
  • IP地址与智能家居能够碰撞出什么样的火花呢?
  • 人工智能技术在电磁场与微波技术专业的应用
  • The First项目报告:探索Yield Guild Games运行机制与发展潜力
  • 完成UI界面的绘制
  • iot网关是什么?iot网关在工业领域的应用-天拓四方
  • 从碎片到整合:EasyCVR平台如何重塑城市感知系统的视频数据生态
  • java socket bio 改造为 netty nio
  • 进程、线程、协程详解:并发编程的三大武器
  • 探索5 大 Node.js 功能
  • EZUIKit.js萤石云vue项目使用
  • 【Linux】磁盘分区挂载网络配置进程【更详细,带实操】
  • Java 为什么使用 UTF-16 而不是更节省内存的 UTF-8?
  • 损失函数篇 | YOLOv10 引入 Inner-IoU 基于辅助边框的IoU损失
  • 夹耳开放式耳机好用吗?一篇文章告诉你答案,附上挑选避坑小知识
  • WebSocket 2024/9/30
  • 大数据开发--1.1大数据概论
  • Java | Leetcode Java题解之第438题找到字符串中所有字母异位词
  • springboot整合MybatisPlus+MySQL
  • 【MySQL】视图、用户和权限管理
  • Linux基础(五):linux文件种类与扩展名
  • C语言-c语言组成
  • 编程题 7-13 日K蜡烛图【PAT】
  • iOS开发工程师面试