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

排序算法---(四)

引言在前几篇文章里面讲到了六种排序今天来讲一下剩下两种基数排序、堆排序基数排序1.思路1首先确定最大数的位数找到待排序数组中的最大数并确定其位数2将元素按照相应的位数存入桶中先定义一个桶二维数组用来存放待排序数组元素再定义一个桶计数器一维数组用来记录每个桶里面有几个元素将元素放入桶中有三步① 放哪个桶看相应位数是多少例如相应位数上是1那么就放在x坐标为1的桶里、② 找到桶应该放在桶内的哪个位置因为相应位数上是同一个数字的可能有多个因此桶计数器发挥作用了若计数为3那说明这个桶已经放了三个元素了那将待放入元素放在第四个位置上、③ 更新桶计数器13相应位数排完序后将存入桶里元素有序的放回原数组2.代码public class jsSort { public static void main(String[] args) { int[] arrnew int[]{5,1,3,9,8,2}; int narr.length; sort(arr); for(int i0;in;i){ System.out.print(arr[i] ); } } public static void sort(int[] arr) { int maxarr[0]; for(int i0;iarr.length;i){ if(arr[i]max){ maxarr[i]; } } int maxLength(max).length(); int[][] bucketnew int[10][arr.length]; int[] bucketCountnew int[10]; int t1; for(int i0;imaxLength;i){ //存数据 for(int j0;jarr.length;j){ int elementarr[j]/t%10; bucket[element][bucketCount[element]]arr[j]; bucketCount[element]; } int index0; //取数据 for(int k0;k10;k){ if(bucketCount[k]!0){ for(int j0;jbucketCount[k];j){ arr[index]bucket[k][j]; } } bucketCount[k]0; } tt*10; } } }堆排序1.相关知识完全二叉树从上到下、从左到右依次填满结点前面每一层必须是满的最后一层可以不满但只能缺右边的结点不能中间空、不能左边空大顶堆在完全二叉树的基础上父节点的值大于左右孩子的值2.思路1首先将待排序数组构造成一个大顶堆此时整个数组最大值就被放在了二叉树的顶端2将堆顶元素和堆底元素进行交换此时堆底元素变成了整个数组最大值3重新构建大顶堆不包含上一步的堆底元素最大值重复上述步骤这样就实现了每次都把最大元素拿出来实现了数组升序3.关键点构造大顶堆从最后一个元素当作parent首先判断是否有孩子childparent*21是否小于nums.length直到找到符合条件的parent找到后开始判断parent和child哪个大大的换到parent位置依次遍历遍历到二叉树的最顶端数组的第一个元素这样不断地向上遍历并交换就实现了堆顶元素是数组最大的元素排除上一轮的堆底元素只需要将待排序数组长度减一即可4.代码public class heapSort { public static void main(String[] args) { int[] arrnew int[]{5,1,3,9,6,8,2}; for(int iarr.length-1;i0;i--){ sort(arr,i,arr.length); } //交换堆顶元素和堆底元素并排除堆底元素 for(int karr.length-1;k0;k--){ int temparr[k]; arr[k]arr[0]; arr[0]temp; sort(arr,0,k); } //循环输出 for(int j0;jarr.length;j){ System.out.print(arr[j] ); } } public static void sort(int[] arr,int parent,int length){ int childparent*21; while(childlength){ int rChildchild1; if(rChildlength arr[rChild]arr[child]){ child; } //将大的元素放在parent位置 if(arr[child]arr[parent]){ int temparr[child]; arr[child]arr[parent]; arr[parent]temp; parentchild; childparent*21; }else{ break; } } } }小舟有话说至此八大排序已全部讲解完毕其中要求我们熟练掌握的有三种排序冒泡排序、快速排序、堆排序大家一定要熟练记忆堆排序虽然看起来难理解但是只要懂了二叉树相关知识就不难。如果觉得内容不错那就点点赞点点关注吧下次找我不迷路~

相关文章:

排序算法---(四)

引言在前几篇文章里面讲到了六种排序,今天来讲一下剩下两种:基数排序、堆排序基数排序1.思路(1)首先确定最大数的位数:找到待排序数组中的最大数,并确定其位数(2)将元素按照相应的位…...

SQL调优实战手册:索引、并行、参数调优一站式解决方案

做企业级业务开发久了,都会碰到同一个难题:数据量越积越多,原本跑得顺畅的SQL慢慢开始变慢,轻则接口响应延迟,重则整个系统卡顿,甚至影响核心业务流转。尤其是用KingbaseES这款国产企业级数据库&#xff08…...

告别跨平台存储难题:exfat-nofuse内核驱动深度实战指南

告别跨平台存储难题:exfat-nofuse内核驱动深度实战指南 【免费下载链接】exfat-nofuse Android ARM Linux non-fuse read/write kernel driver for exFat and VFat Android file systems 项目地址: https://gitcode.com/gh_mirrors/ex/exfat-nofuse 在Linux与…...

Youtu-VL-4B-Instruct图文理解效果集锦:源码部署后生成100+张高质量图片描述样例

Youtu-VL-4B-Instruct图文理解效果集锦:源码部署后生成100张高质量图片描述样例 1. 引言:一个能“看懂”图片的AI助手 想象一下,你随手拍了一张照片,发给一个朋友,他不仅能告诉你照片里有什么,还能分析场…...

3步解决AtlasOS中Xbox控制器驱动问题:从连接失败到畅玩游戏

3步解决AtlasOS中Xbox控制器驱动问题:从连接失败到畅玩游戏 【免费下载链接】Atlas 🚀 An open and lightweight modification to Windows, designed to optimize performance, privacy and security. 项目地址: https://gitcode.com/GitHub_Trending/…...

利用M2LOrder实现安全高效的内网穿透方案设计与验证

利用M2LOrder实现安全高效的内网穿透方案设计与验证 1. 引言 你有没有遇到过这样的麻烦事?自己电脑上开发了一个网站或者服务,想给同事或者客户临时看一下效果,结果发现对方根本访问不了。原因很简单,你的服务跑在公司的内网或者…...

【技术解析】MapReduce:大规模集群上的高效数据处理框架

1. MapReduce框架的核心思想 第一次听说MapReduce时,我正被一个TB级日志分析任务折磨得焦头烂额。传统单机处理需要几十个小时,而当我用上这个框架后,同样任务在200台机器上仅用23分钟就完成了。这种化腐朽为神奇的体验,让我彻底理…...

别再手动复制数组了!用NumPy广播机制5分钟搞定形状不同的数组运算

NumPy广播机制:告别低效循环,用智能扩展提升数组运算效率 你是否曾在处理数据时遇到过这样的场景:需要将一个34的矩阵与一个14的行向量相加,结果却因为维度不匹配而报错?大多数Python初学者会本能地选择用循环或复制数…...

终极指南:用WinDiskWriter在Mac上制作Windows启动盘,简单三步搞定

终极指南:用WinDiskWriter在Mac上制作Windows启动盘,简单三步搞定 【免费下载链接】windiskwriter 🖥 A macOS app that creates bootable USB drives for Windows. 🛠 Patches Windows 11 to bypass TPM and Secure Boot require…...

矩阵按键扫描技术对比:行列扫描与反转扫描的实战解析

1. 矩阵按键扫描技术入门指南 第一次接触矩阵按键时,我完全被那些交叉的行列线搞晕了。直到在某个深夜调试项目时,才突然理解了这个设计的精妙之处——它就像城市道路的十字路口,通过行列坐标就能精准定位每个按键位置。这种设计让16个按键只…...

Awoo Installer:多场景文件部署的跨平台解决方案

Awoo Installer:多场景文件部署的跨平台解决方案 【免费下载链接】Awoo-Installer A No-Bullshit NSP, NSZ, XCI, and XCZ Installer for Nintendo Switch 项目地址: https://gitcode.com/gh_mirrors/aw/Awoo-Installer 问题诊断:Nintendo Switch…...

OFA图像描述模型在STM32嵌入式系统的边缘计算应用

OFA图像描述模型在STM32嵌入式系统的边缘计算应用 让嵌入式设备也能"看懂"世界并说出来 1. 项目背景与需求 你有没有想过,让一个小小的嵌入式设备不仅能"看到"图像,还能用语言描述出它看到了什么?这听起来像是科幻电影里…...

LFM2.5-1.2B-Thinking-GGUF快速上手:使用Ollama本地化部署与管理

LFM2.5-1.2B-Thinking-GGUF快速上手:使用Ollama本地化部署与管理 1. 前言:为什么选择Ollama部署本地大模型 最近大语言模型越来越火,但很多朋友发现云端服务要么太贵,要么有隐私顾虑。今天给大家介绍一个超简单的本地部署方案—…...

选题毫无头绪?高校导师推荐这几个AI论文写作工具

写论文总是卡壳?选题没方向、结构不清晰、文献找不全、语言不专业……这些痛点让很多学生倍感压力。其实,只要用对 AI 工具、走对写作流程,就能大幅提升效率。资深教授普遍建议:千笔AI(中文全流程首选) 豆包…...

springboot-vue+nodejs的公考在线刷题学习平台的设计与实现

目录技术栈选择核心模块设计关键实现步骤扩展功能建议示例代码片段(Spring Boot Controller)注意事项项目技术支持源码获取详细视频演示 :文章底部获取博主联系方式!同行可合作技术栈选择 后端框架:Spring Boot&#…...

C++的std--ranges中的检测引用悬垂

C的std::ranges中的检测引用悬垂:安全迭代的守护者 在现代C编程中,std::ranges库为序列操作提供了更简洁、更安全的抽象。迭代器与范围的使用常伴随一个隐蔽风险:引用悬垂(Dangling References)。当迭代器指向的底层数…...

华硕笔记本显示色彩配置异常问题解决指南

华硕笔记本显示色彩配置异常问题解决指南 【免费下载链接】g-helper Lightweight Armoury Crate alternative for Asus laptops. Control tool for ROG Zephyrus G14, G15, G16, M16, Flow X13, Flow X16, TUF, Strix, Scar and other models 项目地址: https://gitcode.com/…...

7个实用技巧彻底解决Hugo-PaperMod导航菜单不显示问题

7个实用技巧彻底解决Hugo-PaperMod导航菜单不显示问题 【免费下载链接】hugo-PaperMod A fast, clean, responsive Hugo theme. 项目地址: https://gitcode.com/GitHub_Trending/hu/hugo-PaperMod 在使用Hugo-PaperMod主题搭建个人博客时,导航菜单不显示是最…...

李慕婉-仙逆-造相Z-Turbo效果展示:精美动漫角色生成案例

李慕婉-仙逆-造相Z-Turbo效果展示:精美动漫角色生成案例 1. 惊艳效果预览:从文字到动漫角色的魔法 输入一段简单的文字描述,就能生成栩栩如生的动漫角色形象——这就是李慕婉-仙逆-造相Z-Turbo模型带来的神奇体验。作为专为《仙逆》角色李慕…...

揭秘百度技术栈:逆向分析与前沿趋势

技术栈逆向分析基础逆向工程概念与法律边界 常见技术栈识别方法(如Header分析、JS特征、框架指纹) 百度前端技术栈特征(如Baidu-AlloyTeam、San框架)百度搜索前端技术架构页面渲染模式分析(SSR/CSR混合策略&#xff09…...

3个关键技巧优化华硕笔记本性能:GHelper完全指南

3个关键技巧优化华硕笔记本性能:GHelper完全指南 【免费下载链接】g-helper Lightweight Armoury Crate alternative for Asus laptops. Control tool for ROG Zephyrus G14, G15, G16, M16, Flow X13, Flow X16, TUF, Strix, Scar and other models 项目地址: ht…...

OpenRocket完全指南:如何免费设计并仿真你的第一枚模型火箭[特殊字符]

OpenRocket完全指南:如何免费设计并仿真你的第一枚模型火箭🚀 【免费下载链接】openrocket Model-rocketry aerodynamics and trajectory simulation software 项目地址: https://gitcode.com/GitHub_Trending/op/openrocket 你是否曾经梦想设计自…...

告别SQL编写!用Dify打造你的专属数据库对话Agent(含提示词优化技巧)

从零构建智能数据库对话Agent:Dify实战与提示词深度优化指南 在数据驱动的决策时代,非技术用户与数据库之间的鸿沟一直是企业效率的隐形瓶颈。传统SQL查询需要专业知识门槛,而Dify平台的出现,让自然语言到SQL的转换变得触手可及。…...

丹青识画系统快速上手:3步完成镜像部署与首次调用

丹青识画系统快速上手:3步完成镜像部署与首次调用 想试试那个能看懂图片里有什么、还能跟你聊天的AI吗?丹青识画系统就是这么一个有趣的工具。你可能在网上看过一些演示,一张图丢进去,AI就能告诉你图里有啥,甚至能回答…...

为什么顶尖AI团队已弃用Triton+TVM?Cuvil编译器在边缘端低延迟推理中的3大不可替代优势

第一章:Cuvil编译器在Python AI推理中的核心定位与演进逻辑Cuvil编译器并非传统意义上的通用语言编译器,而是专为Python生态中AI模型推理场景深度定制的中间表示(IR)驱动型编译框架。它直面PyTorch/TensorFlow动态图执行开销大、J…...

别再只用欧氏距离了!用Python+NumPy实战马氏距离异常检测(附卡方分布阈值设定)

用Python实战马氏距离异常检测:从理论到工业级实现 在数据分析领域,距离度量是许多算法的基石。当数据维度升高且特征间存在相关性时,传统的欧氏距离就像用一把没有刻度的尺子测量复杂空间——它无法捕捉变量间的相互作用。想象一下金融交易监…...

极简纯净音乐体验:铜钟音乐平台的高效使用指南

极简纯净音乐体验:铜钟音乐平台的高效使用指南 【免费下载链接】tonzhon-music 铜钟 (Tonzhon.com): 免费听歌; 没有直播, 社交, 广告, 干扰; 简洁纯粹, 资源丰富, 体验独特!(密码重置功能已回归) 项目地址: https://gitcode.com/GitHub_Trending/to/t…...

OpenRocket实战手册:从零到精通的火箭设计与仿真完全攻略

OpenRocket实战手册:从零到精通的火箭设计与仿真完全攻略 【免费下载链接】openrocket Model-rocketry aerodynamics and trajectory simulation software 项目地址: https://gitcode.com/GitHub_Trending/op/openrocket 你是否曾经梦想过设计自己的火箭&…...

SlopeCraft:解锁Minecraft地图艺术创作的神器

SlopeCraft:解锁Minecraft地图艺术创作的神器 【免费下载链接】SlopeCraft Map Pixel Art Generator for Minecraft 项目地址: https://gitcode.com/gh_mirrors/sl/SlopeCraft 副标题:面向创意玩家的方块世界艺术生成工具,让照片秒变立…...

揭秘28BYJ-48步进电机的隐藏技能:用Arduino实现0.056°超高精度控制

揭秘28BYJ-48步进电机的隐藏技能:用Arduino实现0.056超高精度控制 在创客和硬件爱好者的世界里,28BYJ-48步进电机因其低廉的价格和广泛的应用而备受青睐。这款电机标称步距角为5.625,看似精度有限,但通过巧妙的驱动技术和算法优化…...