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

快速排序与希尔排序实战解析

一、今天学习目标希尔排序插入排序升级版快速排序最常用、面试必考完整可运行代码复杂度对比二、希尔排序Shell Sort思想分组做插入排序逐步缩小增量gap最后 gap1 时就是普通插入排序但数组已经基本有序非常快// 希尔排序 void shellSort(int arr[], int n) { for (int gap n / 2; gap 0; gap / 2) { for (int i gap; i n; i) { int temp arr[i]; int j; for (j i; j gap arr[j - gap] temp; j - gap) { arr[j] arr[j - gap]; } arr[j] temp; } } }三、快速排序Quick Sort思想选一个基准 pivot小的放左边大的放右边递归左右两部分平均复杂度O(n log n)实际最快。// 交换 void swap(int *a, int *b) { int t *a; *a *b; *b t; } // 划分函数 int partition(int arr[], int low, int high) { int pivot arr[high]; int i low - 1; for (int j low; j high; j) { if (arr[j] pivot) { i; swap(arr[i], arr[j]); } } swap(arr[i 1], arr[high]); return i 1; } // 快排递归 void quickSort(int arr[], int low, int high) { if (low high) { int pi partition(arr, low, high); quickSort(arr, low, pi - 1); quickSort(arr, pi 1, high); } }四、完整测试代码#include stdio.h // swap、shellSort、quickSort、partition 都放这里 void printArr(int arr[], int n) { for (int i 0; i n; i) printf(%d , arr[i]); printf(\n); } int main() { int arr1[] {9, 3, 7, 1, 5, 2, 8, 4, 6}; int n sizeof(arr1) / sizeof(arr1[0]); printf(原数组); printArr(arr1, n); shellSort(arr1, n); printf(希尔排序后); printArr(arr1, n); int arr2[] {9, 3, 7, 1, 5, 2, 8, 4, 6}; quickSort(arr2, 0, n - 1); printf(快速排序后); printArr(arr2, n); return 0; }运行结果原数组9 3 7 1 5 2 8 4 6 希尔排序后1 2 3 4 5 6 7 8 9 快速排序后1 2 3 4 5 6 7 8 9五、复杂度对比表格算法时间复杂度稳定性希尔O(n log n) ~ O(n²)不稳定快排O (n log n) 平均不稳定六、今日小练习对数组{6, 1, 8, 3, 5, 2, 7, 4}分别使用希尔排序、快速排序并输出结果。

相关文章:

快速排序与希尔排序实战解析

一、今天学习目标希尔排序(插入排序升级版)快速排序(最常用、面试必考)完整可运行代码复杂度对比二、希尔排序(Shell Sort)思想:分组做插入排序逐步缩小增量(gap)最后 ga…...

用Python和MATLAB搞定CCA:从数据预处理到结果可视化的完整实战指南

Python与MATLAB双平台实战:典型相关分析(CCA)全流程解析 在金融风控、基因表达分析和工业过程监控等领域,我们常常需要研究两组高维变量之间的关联关系。典型相关分析(CCA)作为多元统计的经典方法,能够揭示变量组间的深层关联模式。本文将带您…...

Adobe-GenP 3.0:解密Adobe全家桶通用补丁的技术实现与应用指南

Adobe-GenP 3.0:解密Adobe全家桶通用补丁的技术实现与应用指南 【免费下载链接】Adobe-GenP Adobe CC 2019/2020/2021/2022/2023 GenP Universal Patch 3.0 项目地址: https://gitcode.com/gh_mirrors/ad/Adobe-GenP Adobe-GenP 3.0是一款基于AutoIt脚本开发…...

ECU测试全攻略:从硬件组成到量产验证

1. ECU测试入门:为什么你的车离不开这个小盒子 每次转动车钥匙时,那个藏在发动机舱角落的小黑盒就开始高速运转。这个不起眼的金属盒子就是ECU(电子控制单元),它像汽车的大脑一样默默工作。我拆解过上百个不同型号的EC…...

动态内存管理:从基础到实战详解

一、为什么需要动态内存?普通数组:长度固定,定义时必须确定大小程序运行时才知道需要多大空间 → 必须用动态内存动态内存从堆区申请,手动申请、手动释放作用:按需申请内存,不浪费可创建变长数组对象动态创…...

文墨共鸣应用场景解析:智能客服、内容审核、论文查重等实战案例分享

文墨共鸣应用场景解析:智能客服、内容审核、论文查重等实战案例分享 你是否遇到过这样的困扰:面对海量的用户咨询,客服团队疲于奔命,回答却总是不尽人意?或者,在审核社区内容时,难以快速准确地…...

如何通过WinUtil工具实现Windows系统优化与软件管理:完整指南

如何通过WinUtil工具实现Windows系统优化与软件管理:完整指南 【免费下载链接】winutil Chris Titus Techs Windows Utility - Install Programs, Tweaks, Fixes, and Updates 项目地址: https://gitcode.com/GitHub_Trending/wi/winutil 你是否曾经为Window…...

别再只跑Demo了!用Fast-ReID训练自定义ReID模型,真正提升你的YoloV5+DeepSORT项目效果

从Demo到实战:基于Fast-ReID打造高精度自定义行人重识别系统 在计算机视觉领域,行人重识别(ReID)技术正逐渐成为智能监控、零售分析和智慧城市等场景中的核心组件。然而,许多开发者在实际项目中常常遇到一个尴尬局面——在演示环境中运行良好…...

**发散创新:用 Rust 实现游戏日中的事件驱动型状态管理引擎**在现

发散创新:用 Rust 实现游戏日中的事件驱动型状态管理引擎 在现代游戏开发中,状态管理是核心难点之一。尤其在“游戏日”这种强调玩家行为反馈与多角色协作的场景下,传统轮询式状态更新机制往往效率低下、耦合度高。本文将带你用 Rust 编程语言…...

Matlab if语句从入门到精通:新手必看的实用指南

文章目录一、if语句的基本结构:最基础也是最核心的用法1.1 单个if的用法1.2 if...else:满足或不满足的双向选择1.3 if...elseif...else:多条件分支判断二、常见的坑点:这些错误你一定要避免2.1 条件表达式必须是标量逻辑值2.2 逻辑…...

Z-Image-Turbo-辉夜巫女网络配置详解:保障高并发下的稳定访问

Z-Image-Turbo-辉夜巫女网络配置详解:保障高并发下的稳定访问 部署好一个强大的AI图像生成服务,比如Z-Image-Turbo-辉夜巫女,只是第一步。当你想把它开放给团队内部使用,或者对外提供API服务时,可能会发现事情没那么简…...

从理论到实践:Fluent流体仿真核心技术与高效操作指南

1. Fluent流体仿真基础理论 第一次接触Fluent时,我被各种专业术语搞得晕头转向。后来发现,理解流体仿真就像学做菜一样,得先认识食材和工具。粘度就是流体的"黏稠度",蜂蜜比水粘度大,这个特性直接影响流动行…...

Windows虚拟声卡终极方案:Scream实现跨设备音频共享的完整指南

Windows虚拟声卡终极方案:Scream实现跨设备音频共享的完整指南 【免费下载链接】scream Virtual network sound card for Microsoft Windows 项目地址: https://gitcode.com/gh_mirrors/sc/scream 想要在不同设备间无线传输电脑音频吗?Scream是一…...

终极指南:3步掌握Mesa智能体建模框架,轻松构建复杂系统仿真

终极指南:3步掌握Mesa智能体建模框架,轻松构建复杂系统仿真 【免费下载链接】mesa Mesa is an open-source Python library for agent-based modeling, ideal for simulating complex systems and exploring emergent behaviors. 项目地址: https://gi…...

三步高效获取国家中小学智慧教育平台电子课本:智能解析工具完整指南

三步高效获取国家中小学智慧教育平台电子课本:智能解析工具完整指南 【免费下载链接】tchMaterial-parser 国家中小学智慧教育平台 电子课本下载工具,帮助您从智慧教育平台中获取电子课本的 PDF 文件网址并进行下载,让您更方便地获取课本内容…...

告别数据线束缚:QCMA,你的PS Vita内容管理智能助手

告别数据线束缚:QCMA,你的PS Vita内容管理智能助手 【免费下载链接】qcma Cross-platform content manager assistant for the PS Vita 项目地址: https://gitcode.com/gh_mirrors/qc/qcma 你是否曾经为PS Vita繁琐的数据传输而烦恼?想…...

建议所有人前端准备到这种程度再去面试

别再裸面了,有些坑你根本想不到最近帮团队筛了上百份前端简历,也面了四十多个候选人。说实话,大部分人连第一轮都过不了——不是因为基础差,而是完全不知道面试官到底在考什么。 有人能把 三大框架的源码讲得头头是道&#xff0c…...

YDFID-1:如何用开源数据集彻底革新纺织行业的AI质检?

YDFID-1:如何用开源数据集彻底革新纺织行业的AI质检? 【免费下载链接】YDFID-1 Yarn-dyed Fabric Image Dataset Version1. From Zhang Hongwei, Artificial Intelligence Research Group, Xi an Polytechnic University. 项目地址: https://gitcode.c…...

告别重复图片困扰:AntiDupl.NET帮你智能清理硬盘空间 [特殊字符]️

告别重复图片困扰:AntiDupl.NET帮你智能清理硬盘空间 🖼️ 【免费下载链接】AntiDupl A program to search similar and defect pictures on the disk 项目地址: https://gitcode.com/gh_mirrors/an/AntiDupl 你是否曾经在整理照片时发现同一张图…...

RGB-IR 双模态目标检测系列六|原创 3 大频域小波融合模块!LWFM/SA-WFM/DGFM 全线碾压 Concat,轻量即插即用涨点狂飙!

🔥 本文定位:CSDN 原创 VIP 干货|双模态频域融合天花板|3 大自研模块|YOLOv8/v11全适配|小目标 / 夜间低光暴涨点🎯 核心收益:彻底抛弃传统 Concat/Add/ 通道注意力融合,…...

手把手教你用STM32F4+ESP8266做个能听会说的智能音箱(附完整代码)

从零打造智能音箱:STM32F4与ESP8266的完美组合实战指南 智能音箱早已不再是科技发烧友的专属玩具,越来越多家庭开始享受语音交互带来的便利。但市面上大多数产品都是封闭系统,无法满足DIY爱好者的探索欲望。今天,我们将用STM32F4开…...

Hyperf方案 微服务拆分策略与实践

微服务拆分在 Hyperf 生态里有完整工具链:┌───────────────┬──────────────────────────────────────────┐│ 关注点 │ 库 │ …...

终极指南:5分钟免费解锁Cursor AI Pro完整功能的完整解决方案

终极指南:5分钟免费解锁Cursor AI Pro完整功能的完整解决方案 【免费下载链接】cursor-free-vip [Support 0.45](Multi Language 多语言)自动注册 Cursor Ai ,自动重置机器ID , 免费升级使用Pro 功能: Youve reached y…...

深入PCA9685数据手册:手把手教你用STM32的IIC调试其所有寄存器(附逻辑分析仪实测波形)

STM32与PCA9685深度协同:从寄存器配置到多舵机精准控制实战 引言 在机器人关节控制、智能家居设备驱动等场景中,多路PWM信号的高精度同步输出一直是硬件开发者面临的挑战。传统STM32芯片的定时器资源有限,当需要控制多个舵机时往往力不从心。…...

别再让root用户坑你了!Linux服务器上UE4.22编译报错‘Makefile:212’的保姆级修复指南

别再让root用户坑你了!Linux服务器上UE4.22编译报错‘Makefile:212’的保姆级修复指南 最近在Linux服务器上部署Unreal Engine 4.22的开发环境时,不少开发者都遇到了一个看似简单却令人头疼的问题:使用root用户编译时,系统抛出Ma…...

图像压缩ONNX模型跨平台推理一致性问题解决方案

图像压缩ONNX模型跨平台推理一致性问题解决方案 摘要 随着深度学习技术的快速发展,基于学习型图像压缩(Learned Image Compression, LIC)算法在压缩效率上已超越传统图像编码技术,逐渐向工业应用迈进。然而,在实际部署过程中,一个关键问题凸显出来:非确定性计算导致概…...

深入解析基4 Booth算法在定点乘法器中的高效实现

1. 从买菜到芯片:为什么需要基4 Booth算法? 记得我第一次接触乘法器设计时,脑子里全是菜市场阿姨算账的画面。比如买3斤苹果,每斤5元,阿姨会脱口而出"三五十五"。但在芯片世界里,这种简单的乘法却…...

象州站计算机联锁工程设计复现

象州站计算机联锁工程设计复现 摘要 本文基于谢岷桐同学的本科毕业设计《象州站计算机联锁工程设计》,对该设计进行完整的技术复现与代码实现。象州站为双线区段车站,正线采用60kg/m的12号普通道岔,侧线采用50kg/m的9号普通道岔,共有5条股道、27架信号机。本文通过Python…...

测试深度策略

** 测试深度常用策略 ** 按覆盖深度 需求覆盖:每条需求都有对应用例,不漏场景功能覆盖:主流程、分支、异常、边界都测到接口覆盖:入参、出参、必填/非必填、枚举、错误码代码覆盖:语句、分支、条件、路径覆盖&#xff…...

差分式升压逆变器MATLAB仿真模型设计——实现110V/50Hz输出电压与THD<5%

差分式升压逆变器MATLAB仿真模型设计——实现110V/50Hz输出电压与THD<5% 摘要 差分式升压逆变器(Differential Boost Inverter, DBI)是一种能够将低压直流电源直接转换为高压交流输出的单级电力电子变换器拓扑结构。与传统两级式(DC-DC升压+DC-AC逆变)方案相比,DBI省…...