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

排序(五)【数据结构】

快速排序核心思想将待排序序列围绕着基本值分成两部分左边部分都小于基准值右边部分都大于基准值第一种方法递归优点:简单 缺点:需要单独开辟辅助空间brr数组第二种方法挖空法很重要快速排序的单次划分函数 PartitionintPartition(intarr[],intleft,intright){//挖空法步骤:核心函数(単吹划分函数 Partition)//1.默认将第一个值(arr[left])当做基准值拷贝给tmpinttmparr[left];//2.进入到while循环(循环条件是两个指针没有相遇)while(leftright){//3.先从右至左找比基准值小的值找到后扔到左边空位上|()while(leftrightarr[right]tmp)right--;//while循环退出有两种情况//情况1left和right相遇了说明划分可以结束了基准值要放回去了//情况2left和right没有相遇但是找到了一个小于或等于tmp的值if(leftright){break;}arr[left]arr[right];//4.再从左至右找比基准值大的值找到后扔到右边空位上|()while(leftrightarr[left]tmp)left;//while循环退出有两种情况//情况1left和right相遇了说明划分可以结束了基准值要放回去了//情况2left和right没有相遇但是找到了一个大于tmp的值if(leftright){break;}arr[right]arr[left];}//5.重复345过程直到两个指针相遇while循环退出//6.while循环退出后则两个指针相遇的位置就是基准值所该在的位置(把tmp拷贝回去)//7.将最后基准值所在下标返回arr[left]tmp;//arr[right] tmp;returnleft;//return right;}快排的递归函数voidQuick(intarr[],intleft,intright){if(leftright){return;}intparPartition(arr,left,right);//以基准值所在下标par可以将原本的范围[LEFTRIGHT]分成两个部分//左边部分的有效范围[LEFT, par-1]//右边部分的有效范围[par1, RIGHT]Quick(arr,left,par-1);Quick(arr,par1,right);/*if (left par - 1) { Quick(arr, left, par - 1); } if (par 1 right) { Quick(arr, par 1, right); } */}快速排序主体voidQuick_Sort(intarr[],intlen){Quick(arr,0,len-1);}快速排序的非递归实现#includestack//快速排序非递归实现voidQuick_No_Recursion(intarr[],intlen){//0.断言assert(arr!NULL);//1.申请一个栈并将初始状态下的0,len-1入到栈里std::stackintst;st.push(0);st.push(len-1);//2.进入while循环循环条件是栈不空即可while(!st.empty()){//3.进来之后取出一组数据用来表示当前partition函数要单次划分的数据的左右边界intrightst.top();st.pop();intleftst.top();st.pop();//4.调用单次划分函数partition并将其返回值返回的是其基准值所在下标用变量par接收下intparPartition(arr,left,right);//5.再对当前基准值两侧的数据个数进行判定如果数据量在2个及以上则将其左右边界一起压到栈里if(leftpar-1){st.push(left);st.push(par-1);}if(par1right){st.push(par1);st.push(right);}}//6.当while循环结束代表所有要处理的数据块都被partition函数处理掉了}快速排序的特点数据越乱反而效率越高优化方案方案1数据量如果少的话直接转头去调用直接插入排序//快速排序voidQuick_Sort(intarr[],intlen){//优化方法1数据量如果小的话直接去调用直接插入排序if(len100){Insert_Sort2(arr,len);return;}Quick(arr,0,len-1);}方案2三数取中法//三数取中法voidThree_Nums_GetMid(intarr[],intleft,intright){intmid(rightleft)/2;//1.先对左端值和中间值进行比较如果左端值大于中间位置值则交换if(arr[left]arr[mid]){inttmparr[mid];arr[mid]arr[left];arr[left]tmp;}//此时一定左端和中间位置的那个较大值一定在中间//2。再对此时中间位置和右端值进行比较如果中间位置值大于右端值则交换if(arr[mid]arr[right]){inttmparr[mid];arr[mid]arr[right];arr[right]tmp;}//此时一定三个位置中的那个最大值在此时的右端位置而我们要找的那个不大不小的值在中间//3.对此事左端值和中间位置值进行比较如果左端值小于中间位置值则交换if(arr[mid]arr[left]){inttmparr[mid];arr[mid]arr[left];arr[left]tmp;}}方案3随机数法

相关文章:

排序(五)【数据结构】

快速排序 核心思想 将待排序序列,围绕着基本值分成两部分,左边部分都小于基准值,右边部分都大于基准值 第一种方法:递归 优点:简单 缺点:需要单独开辟辅助空间brr数组 第二种方法:挖空法(很重要&…...

Davinci NvM Block与Fee Block关联配置详解

1. Davinci配置工具中的NvM与Fee Block基础概念 第一次接触Davinci配置工具时,很多人会对NvM Block和Fee Block的关系感到困惑。简单来说,NvM(Non-volatile Memory)Block是我们配置的非易失性存储单元,而Fee&#xff0…...

如何快速上手AssetStudio:Unity游戏资源提取的终极指南

如何快速上手AssetStudio:Unity游戏资源提取的终极指南 【免费下载链接】AssetStudio AssetStudio - Based on the archived Perfares AssetStudio, I continue Perfares work to keep AssetStudio up-to-date, with support for new Unity versions and additional…...

程序员效率工具:Yi-Coder-1.5B部署与真实任务测试报告

程序员效率工具:Yi-Coder-1.5B部署与真实任务测试报告 还在为写一个简单的文件处理脚本而翻遍搜索引擎吗?或者面对一段陌生的遗留代码,需要花半小时去理解它的逻辑?对于程序员来说,日常开发中充斥着大量重复、琐碎但必…...

避坑指南:用C++在ROS2中实现LOAM建图与定位时,如何解决PCL、Eigen和g2o的版本兼容与编译问题

ROS2环境下LOAM算法实战:PCL、Eigen与g2o版本兼容性深度解决方案 当你在ROS2环境中实现LOAM(Lidar Odometry and Mapping)算法时,PCL、Eigen和g2o这三个关键库的版本兼容性问题往往会成为项目推进的最大障碍。本文将深入剖析这些依…...

22 华夏之光永存:指挥AI修复自身代码bug,无需人工逐行查找

指挥AI修复自身代码bug,无需人工逐行查找 摘要 本文为《30天掌控AI编程:从指令到落地,手把手教你指挥AI写代码》系列第二十二篇,属于第四阶段「AI代码校验与优化」核心内容。承接上篇AI代码校验成果,本篇聚焦AI代码bug自动化修复,针对零基础开发者“不会改bug、改完又出…...

OpenClaw异常处理设计:Qwen3.5-9B图片任务失败自动恢复方案

OpenClaw异常处理设计:Qwen3.5-9B图片任务失败自动恢复方案 1. 为什么需要异常处理机制? 上周我尝试用OpenClawQwen3.5-9B实现证件照自动裁剪时,遇到了典型的"三连击"问题:网络波动导致图片上传中断、模型响应超时、输…...

seo推广员如何进行用户体验优化_seo推广员的工作内容有哪些

SEO推广员如何进行用户体验优化 在当今的数字化时代,用户体验(UX)已经成为网站运营和SEO推广的重要组成部分。一个优秀的用户体验不仅能够提高用户的满意度和忠诚度,还能直接影响网站的SEO表现。作为一名SEO推广员,如…...

Qwen3-14B镜像快速入门:内置模型+完整环境,开箱即用教程

Qwen3-14B镜像快速入门:内置模型完整环境,开箱即用教程 1. 为什么选择Qwen3-14B镜像 在AI模型部署过程中,环境配置往往是最耗时的环节。传统部署方式需要手动安装CUDA、PyTorch、模型权重等数十个组件,版本兼容性问题频发&#…...

嵌入式电机控制基础库:DC/步进/BLDC寄存器级驱动解析

1. 项目概述“Motor”是一个面向教育与工程实践的嵌入式电机控制基础库,由奥地利HTL-Graz-Gssing(现为HTL Graz-Gssing,原Bertl2014教学项目)开发并维护,专为中等技术学校(HTL)电子与自动化专业…...

Golang如何做API网关_Golang API网关教程【必看】

...

Xinference-v1.17.1实现Python爬虫数据智能处理:自动化采集与清洗

Xinference-v1.17.1实现Python爬虫数据智能处理:自动化采集与清洗 1. 引言 做数据采集的朋友们都知道,写爬虫最头疼的不是写代码本身,而是面对各种网站结构变化、反爬机制、数据清洗这些繁琐工作。每次网站改版,爬虫代码就得重写…...

如何防止SQL注入篡改应用配置_对数据库连接加密存储

能,但需满足配置存数据库且SQL未参数化;攻击者可通过拼接恶意语句读取、删表或篡改配置;加密须用外部KMS管理密钥,避免硬编码,并配合权限隔离、输入校验与TLS传输。SQL注入能直接改配置表吗?能,…...

HunyuanVideo-Foley多模态交互案例:结合文本与视觉输入生成场景化音效

HunyuanVideo-Foley多模态交互案例:结合文本与视觉输入生成场景化音效 1. 效果亮点开场 想象一下这样的场景:你上传一张古堡图片,输入"添加一些神秘感",系统就能自动生成风声、吱呀作响的木门、隐约的钟声等复合音效。…...

静态图分布式训练总失败?PyTorch 3.0官方未公开的3类隐式依赖、4个环境校验checklist,立即自查!

第一章:静态图分布式训练失败的典型现象与归因框架静态图分布式训练(如 TensorFlow 1.x Graph 模式或 MindSpore Graph 模式)在大规模模型训练中常因图构建期与执行期分离的特性,导致错误暴露滞后、定位困难。典型失败现象包括&am…...

微信接入支付宝内置的openclaw(aclaw)

第一步:领养龙虾第二步:安装微信插件 让 AClaw 执行以下命令: npx -y tencent-weixin/openclaw-weixin-clilatest install将命令发送给 AClaw,效果如图所示:第三步:扫码登录 由于运行环境的限制&#xff0c…...

从零开始:用EmbeddingGemma-300M搭建学术论文溯源系统

从零开始:用EmbeddingGemma-300M搭建学术论文溯源系统 1. 学术论文溯源系统的核心价值 在科研工作中,我们经常遇到这样的困境:阅读一篇论文时,发现某个重要结论似曾相识,却怎么也想不起具体出处;或是想验…...

Qwen3-ASR-1.7B一文详解:GPU算力适配策略与batch size调优经验

Qwen3-ASR-1.7B一文详解:GPU算力适配策略与batch size调优经验 1. 引言:从“能用”到“好用”的语音识别进阶 当你第一次部署Qwen3-ASR-1.7B时,可能会发现一个有趣的现象:上传一段音频,点击识别,几秒钟后…...

Qwen3-TTS开源镜像部署:RabbitMQ消息队列解耦高并发语音合成任务

Qwen3-TTS开源镜像部署:RabbitMQ消息队列解耦高并发语音合成任务 1. 项目概述与核心价值 Qwen3-TTS-12Hz-1.7B-VoiceDesign是一个功能强大的语音合成模型,支持10种主要语言(中文、英文、日文、韩文、德文、法文、俄文、葡萄牙文、西班牙文和…...

ScriptGen Modern Studio在短视频/微短剧创作中的应用实战

ScriptGen Modern Studio在短视频/微短剧创作中的应用实战 1. 短视频创作的新工具革命 短视频和微短剧行业正在经历前所未有的爆发式增长。根据最新行业报告,2023年短视频内容创作量同比增长超过60%,而专业级微短剧的市场规模预计将在2025年突破千亿大…...

OpenClaw监控方案:Qwen3-4B模型API健康检查自动化

OpenClaw监控方案:Qwen3-4B模型API健康检查自动化 1. 为什么需要模型API监控 上周我的个人自动化流程突然中断了整整8小时——直到第二天早上查看日志才发现是Qwen3-4B模型API服务崩溃了。这个教训让我意识到:本地部署的大模型也需要像云服务一样建立健…...

FireRedASR-AED-L在STM32项目中的应用:离线语音指令识别原型开发

FireRedASR-AED-L在STM32项目中的应用:离线语音指令识别原型开发 最近在做一个智能家居控制的小项目,核心想法挺简单:对着设备说句话,它就能听懂并执行开关灯、调节风扇之类的操作。听起来是不是有点像智能音箱?但我的…...

OpenClaw小团队协作:Qwen3.5-9B共享模型端点的权限管理

OpenClaw小团队协作:Qwen3.5-9B共享模型端点的权限管理 1. 为什么小团队需要共享OpenClaw实例 去年我们实验室遇到一个典型问题:五个研究员共用三台GPU服务器,每个人都想用OpenClaw做自动化实验,但各自部署不仅浪费资源&#xf…...

KART-RERANK模型实战:构建个人知识库的智能搜索引擎

KART-RERANK模型实战:构建个人知识库的智能搜索引擎 你有没有过这样的经历?想找一篇之前看过的技术文章,隐约记得在某个PDF里,或者在某个收藏夹里,但就是死活想不起来具体在哪。于是,你开始在电脑里翻找&a…...

Cesium实战:天地图三维服务接入与优化指南

1. 天地图三维服务与Cesium的完美结合 第一次接触天地图三维服务时,我被它丰富的地理数据和稳定的服务性能所吸引。作为国内领先的地理信息服务提供商,天地图不仅提供基础地图数据,还支持三维地形、影像、矢量等多种数据类型的调用。而Cesium…...

若依框架多级目录闪退问题解决:手把手教你添加router-view的正确姿势

若依框架多级目录闪退问题深度解析与实战修复指南 最近在若依框架的实际项目开发中,不少前端工程师反馈遇到一个棘手问题:当系统包含多级目录菜单时,点击后菜单会在页面中短暂闪现随即消失。这种现象不仅影响用户体验,也暴露出框架…...

云容笔谈多语言支持实践:中英日韩提示词对齐与东方语义保真度验证

云容笔谈多语言支持实践:中英日韩提示词对齐与东方语义保真度验证 1. 引言:当东方美学遇见全球用户 想象一下,一位来自日本的插画师,想创作一位身着“十二单”的平安时代贵族女性;一位韩国的游戏美术,需要…...

Navicat Premium 16快捷键全攻略:从SQL注释到窗口切换,提升效率的10个必备技巧

Navicat Premium 16快捷键全攻略:从SQL注释到窗口切换,提升效率的10个必备技巧 在数据库管理的日常工作中,效率往往取决于细节。Navicat Premium 16作为一款功能强大的数据库管理工具,其快捷键系统就像隐藏在界面之下的效率引擎。…...

YOLO12入门必看:位置感知器与FlashAttention推理加速原理图解

YOLO12入门必看:位置感知器与FlashAttention推理加速原理图解 1. YOLO12模型概述 1.1 新一代目标检测架构 YOLO12是2025年发布的最新一代目标检测模型,代表了计算机视觉领域的重要突破。这个模型采用了全新的注意力为中心架构,在保持实时推…...

STC8H8K32U按键控制OLED显示

手动按键按下,OLED显示对应键值 气缸前进后退电机正反转本文实现了一个基于STC8H单片机的按键检测与OLED显示系统。系统通过8个独立按键输入信号,采用消抖算法检测有效按键,并在OLED屏幕上实时显示对应按键编号。程序包含OLED初始化、I2C通信协议实现、按…...