排序算法---希尔排序

1. 基本思想 

希尔排序是插入排序的一种,它与直接插入排序不同的是,它会优先比较距离较远的元素,因此希尔排序又被称为“缩小增量排序”。希尔排序的实现思路是:先将整个待排序的记录序列分割成为若干子序列分别进行直接插入排序,待整个序列中的记录“基本有序”时,再对全体记录进行依次直接插入排序。

 2. 实现逻辑

(1)首先选取一个步长gap,通常是数组长度的一半,向上取整和向下取整都可以

(2)所有距离为gap的倍数的记录放在同一个组中,在各组内进行直接插入排序。

(3)改变步长 gap = gap/2,  重复操作,直至完全有序

 3. 案例:

对数组  [9,1,2,5,7,4,8,6,3,5]  进行排序

3.1 流程图 

 

3.2 实现代码

        function shellSort(arr) {let len = arr.lengthlet count = 0for (let gap = parseInt(len / 2); gap > 0; gap = parseInt(gap / 2)) {// 外层循环将数组分成若干组for (let i=gap; i<len; i++) {  // 内层遍历每组中所有的元素,对每一组进行插入排序for (let j=i-gap; j>=0; j-=gap) {if (arr[j] > arr[j+gap]){let temp = arr[j]arr[j] = arr[j+gap]arr[j+gap] = temp}}}console.log(`希尔排序第${++count}轮结束后,数组变为:${arr}`)}}let arr = [9,1,2,5,7,4,8,6,3,5]shellSort(arr)

 3.3 结果

 

4. 复杂度分析

4.1 时间复杂度

 

 4.2 空间复杂度

 

4.3 稳定性

我们在分布对数组进行排序的时候,很有可能将两个相同值的元素的相对位置进行改变,所以希尔排序是不稳定的排序算法

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/218669.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

​flutter 代码混淆

Flutter 应用混淆&#xff1a;Flutter 应用的混淆非常简单&#xff0c;只需要在构建 release 版应用时结合使用 --obfuscate 和 --split-debug-info 这两个参数即可。–obfuscate --split-debug-info 用来指定输出调试文件的位置&#xff0c;该命令会生成一个符号映射表。目前支…

智能驾驶时代加速到来,爱芯元智成车载芯片界最大黑马?

今年以来&#xff0c;随着新能源汽车厂商们轰轰烈烈的“开城之战”持续上演&#xff0c;国内新能源汽车行业俨然已进入智能驾驶时代。在这场技术革新大潮中&#xff0c;扮演重要角色的除了处于视觉中心风光无两的车企&#xff0c;还有上游诸多的智能驾驶方案供应商。 下游的军…

C 语言USB通信之使用 libusb库

在C语言中&#xff0c;要与USB接口通信&#xff0c;通常需要使用特定的库和API。以下是一些常见的库和API&#xff0c;用于在C语言中与USB接口通信&#xff1a; libusb&#xff1a;这是一个开源的USB库&#xff0c;提供了跨平台的USB设备访问功能。它提供了API&#xff0c;使您…

MS913/914 25-100MHz 10/12 位用于平面显示器链路Ⅲ的具有直流平衡编码和双向控制通道的串化器和解串器

MS913/MS914 芯片组是 25MHz~100MHz 10 位/12 位 FPD Link III SER/DES(串化器/解串器)&#xff0c;它提供高速 FPD-Link III 接口和高速正向通路以及用于差分对上数据发送的双向 控制通路。广泛应用于车载摄像&#xff0c;医疗设备&#xff0c;管道探测等领 域。 主要特点…

master分支切换到release分支

commit master分支的代码 glol 查看当前分支的commit id git checkout 2023.12_rel gl git checkout -b 分支名 gcp commit_id(glol) git push --set-upstream origin 分支名

lwIP 细节之六:connected、sent、poll 回调函数是何时调用的

使用 lwIP 协议栈进行 TCP 裸机编程&#xff0c;其本质就是编写协议栈指定的各种回调函数。将你的应用逻辑封装成函数&#xff0c;注册到协议栈&#xff0c;在适当的时候&#xff0c;由协议栈自动调用&#xff0c;所以称为回调。 注&#xff1a;除非特别说明&#xff0c;以下内…

HarmonyOS4.0从零开始的开发教程11Video组件的使用

HarmonyOS&#xff08;九&#xff09;Video组件的使用 概述 在手机、平板或是智慧屏这些终端设备上&#xff0c;媒体功能可以算作是我们最常用的场景之一。无论是实现音频的播放、录制、采集&#xff0c;还是视频的播放、切换、循环&#xff0c;亦或是相机的预览、拍照等功能…

OpenCloud os 9上面安装docker docker-compose脚本

#!/bin/bash #opencloudOs上面安装docker docker-compose环境 curl -o /etc/yum.repos.d/docker-ce.repo https://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo sed -i s/\$releasever/8/g /etc/yum.repos.d/docker-ce.repo wget https://vault.centos.org/ce…

C++异步网络库workflow入门教程(1)HTTP任务

如果觉得小弟写的可以,请给一个点赞关注支持 workFlow c异步网络库编译教程与简介 创建并启动http任务 示例 #include <workflow/WFFacilities.h> int main(){WFHttpTask * httpTask WFTaskFactory::create_http_task("http://baidu.com",0,0,0);protocol:…

Python码上行动系列丛书(由北京大学出版社出版)

前言 Python码上行动系列丛书火热来袭&#x1f4a5;&#x1f4a5;&#x1f4a5; 三册在手&#xff0c;Python全掌握&#xff01;无论是初学者还是进阶玩家&#xff0c;我们都有你想要的&#xff01; 让ChatGPT带你轻松入门Python编程&#xff0c;享受编程带来的乐趣&#xff0…

【数据结构】——二叉树功能

前言&#xff1a;我们前面已经了解了二叉树的一些概念&#xff0c;那么我们今天就来了解下二叉树的遍历实现和一些性质。 二叉树的遍历方式有三种&#xff1a;前序&#xff0c;中序&#xff0c;后序。 前序&#xff1a;先根节点&#xff0c;再左子树&#xff0c;最后右子树。 中…

Linux——MySQL数据库系统()

一、访问MySQL数据库 MySQL数据库系统也是一个典型的C/S(客户端/服务器&#xff09;架构的应用&#xff0c;要访问MySQL数据库需要使用专门的客户端软件。在Linux系统中&#xff0c;最简单、易用的MySQL客户端软件是其自带的mysql命令工具。 1、登录到MySQL服务器经过安装后的初…

Leetcode—783.二叉搜索树节点最小距离【简单】

2023每日刷题&#xff08;五十八&#xff09; Leetcode—783.二叉搜索树节点最小距离 实现代码 /*** Definition for a binary tree node.* struct TreeNode {* int val;* struct TreeNode *left;* struct TreeNode *right;* };*/ void dfs(struct TreeNode* roo…

在接触新的游戏引擎的时候,如何能快速地熟悉并开发出一款新游戏?

引言 大家好&#xff0c;今天分享点个人经验。 有一定编程经验或者游戏开发经验的小伙伴&#xff0c;在接触新的游戏引擎的时候&#xff0c;如何能快速地熟悉并开发出一款新游戏&#xff1f; 利用现成开发框架。 1.什么是开发框架&#xff1f; 开发框架&#xff0c;顾名思…

微信抖音快手QQ小程序 - 预支付接口参数out_trade_no长度限制 - jsapi统一下单接口

报错 微信小程序&#xff1a; {"code":0,"show":1,"msg":"输入源“/body/xml/out_trade_no”映射到值字段“商户订单号”字符串规则校验失败&#xff0c;字节数 35&#xff0c;大于最大值 32","data":{"from":&q…

【goland如果使用xorm执行mysql的存储过程】

goland如果使用xorm执行mysql的存储过程 需求背景 存在用户表和用户邀请关系表&#xff0c;当用户A邀请用户B&#xff0c;则B用户为A用户直接邀请的人&#xff1b;B用户邀请了C用户&#xff0c;则C用户就是A用户的间接邀请人。 如何查询当前用户间接邀请的注册用户有那些&am…

ROS2 学习08 导航Nav2:简介、安装、测试效果、错误处理

1、简介 在ROS2中自动导航使用Nav2来实现。 Nav2 使用几个独立的模块化服务&#xff0c;通过 ROS 2接口&#xff08;例如动作服务器或服务&#xff09;与行为树 (BT) 通信。 Nav2 输入包括&#xff1a;TF转换、一个地图源、一个行为树 (BT) XML 文件和相关的传感器数据源; Nav…

每日学习打卡

文章目录 12月份学习&#xff1a;牛客网刷题 12月份学习&#xff1a;牛客网刷题 12/11 周一12/12 周二12/13 周三12/14 周四12/15 周五牛客网1_非技术快速入门&#xff1a;26-39 ✅牛客网1_非技术快速入门&#xff1a;复习1-39 ✅牛客网2_SQL基础进阶&#xff1a;1-18牛客网2_…

C语言好题分享七(三数之和)

❀❀❀ 文章由不准备秃的大伟原创 ❀❀❀ ♪♪♪ 若有转载&#xff0c;请联系博主哦~ ♪♪♪ ❤❤❤ 致力学好编程的宝藏博主&#xff0c;代码兴国&#xff01;❤❤❤ 三数之和 题目来源LeetCode&#xff1a;刷题传送门 题目&#xff1a;给你一个整数数组 nums &#xff0c;判断…

EasyRecovery2024专业版下载安装步骤图文详细教程

EasyRecovery是一款操作安全、价格便宜、用户自主操作的非破坏性的只读应用程序&#xff0c;它不会往源驱上写任何东西&#xff0c;也不会对源驱做任何改变。它支持从各种各样的存储介质恢复删除或者丢失的文件&#xff0c;其支持的媒体介质包括&#xff1a;硬盘驱动器、光驱、…