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

Java 面试手撕排序封神版!八大排序算法(快排 / 堆排 / 归并)手敲无 bug,面试直接默写

面试手撕排序整理完整版面试中常考的手撕排序算法整理可以直接照抄包含快速排序归并排序堆排序希尔排序直接插入排序选择排序计数排序冒泡排序快速排序丐版实现publicstaticvoidquickSort(ArrayListIntegerarr,intbegin,intend){if(beginend){return;}intleftbegin;intrightend;intpivotarr.get(begin);//pivot是基准值while(leftright){while(leftrightarr.get(right)pivot){right--;}while(leftrightarr.get(left)pivot){left;}Collections.swap(arr,left,right);}Collections.swap(arr,left,begin);quickSort(arr,begin,left-1);quickSort(arr,left1,end);}小区间优化 随机数优化避免递归过深publicstaticvoidquickSort(ArrayListIntegerarr,intbegin,intend){if(beginend){return;}if(end-begin110){insertSort(arr,begin,end);return;}intleftbegin;intrightend;intrandrandom.nextInt(end-begin1)begin;Collections.swap(arr,rand,begin);intpivotarr.get(begin);//pivot是基准值while(leftright){while(leftrightarr.get(right)pivot){right--;}while(leftrightarr.get(left)pivot){left;}Collections.swap(arr,left,right);}Collections.swap(arr,left,begin);quickSort(arr,begin,left-1);quickSort(arr,left1,end);}这里也可以不采取随机数其他方法也可以比如三数取中。核心思想就是避免有序数组对排序造成递归过深的问题堆排序publicstaticvoidheapSort(ArrayListIntegerarr){intnarr.size();for(inti(n-1-1)/2;i0;i--){adjustDown(arr,i,arr.size()-1);}intendarr.size()-1;while(end0){Collections.swap(arr,0,end);end--;adjustDown(arr,0,end);}}privatestaticvoidadjustDown(ArrayListIntegerarr,intparent,intend){intchildparent*21;while(childend){if(child1endarr.get(child)arr.get(child1)){child1;}if(arr.get(child)arr.get(parent)){Collections.swap(arr,child,parent);parentchild;childparent*21;}else{break;}}}归并排序publicstaticvoidmergeSort(ArrayListIntegerarr){ArrayListIntegerbuffernewArrayList(arr);_mergeSort(arr,0,arr.size()-1,buffer);}publicstaticvoid_mergeSort(ArrayListIntegerarr,intbegin,intend,ArrayListIntegerbuffer){if(beginend){return;}intmidi(beginend)/2;_mergeSort(arr,begin,midi,buffer);_mergeSort(arr,midi1,end,buffer);intleftbegin;intrightmidi1;intibegin;while(leftmidirightend){if(arr.get(left)arr.get(right)){buffer.set(i,arr.get(left));}else{buffer.set(i,arr.get(right));}}while(leftmidi){buffer.set(i,arr.get(left));}while(rightend){buffer.set(i,arr.get(right));}for(intjbegin;jend;j){arr.set(j,buffer.get(j));}}希尔排序publicstaticvoidshellSort(ArrayListIntegerarr){intnarr.size();intgaparr.size();while(gap1){gapgap/2;for(inti0;in-gap;i){intendi;inttmparr.get(endgap);while(end0){if(arr.get(end)tmp){arr.set(endgap,arr.get(end));end-gap;}else{break;}}arr.set(endgap,tmp);}}}插入排序publicstaticvoidinsertSort(ArrayListIntegerarr){for(inti0;iarr.size()-1;i){intendi;inttmparr.get(end1);while(end0){if(arr.get(end)tmp){arr.set(end1,arr.get(end));end--;}else{break;}}arr.set(end1,tmp);}}选择排序publicstaticvoidselectSort(ArrayListIntegerarr){intleft0,rightarr.size()-1;for(inti0;iarr.size();i){if(leftright){break;}intminleft;intmaxleft;for(intjleft;jright;j){if(arr.get(j)arr.get(min)){minj;}if(arr.get(j)arr.get(max)){maxj;}}Collections.swap(arr,left,min);if(maxleft){maxmin;}Collections.swap(arr,right,max);left;right--;}}计数排序publicstaticvoidcountSort(ArrayListIntegerarr){intmaxInteger.MIN_VALUE,minInteger.MAX_VALUE;for(inti0;iarr.size();i){if(arr.get(i)max){maxarr.get(i);}if(arr.get(i)min){minarr.get(i);}}intsizemax-min1;int[]bufnewint[size];for(inti0;iarr.size();i){buf[arr.get(i)-min];}intm0;for(intn0;nsize;n){while(buf[n]!0){arr.set(m,nmin);buf[n]--;}}}冒泡排序publicstaticvoidbubbleSort(ArrayListIntegerarr){if(arr.size()1){return;}for(inti0;iarr.size();i){booleanflagfalse;for(intj1;jarr.size()-i;j){if(arr.get(j-1)arr.get(j)){Collections.swap(arr,j-1,j);flagtrue;}}if(flagfalse){break;}}}

相关文章:

Java 面试手撕排序封神版!八大排序算法(快排 / 堆排 / 归并)手敲无 bug,面试直接默写

面试手撕排序整理完整版 面试中常考的手撕排序算法整理&#xff0c;可以直接照抄&#xff0c;包含 快速排序归并排序堆排序希尔排序直接插入排序选择排序计数排序冒泡排序 快速排序 丐版实现 public static void quickSort(ArrayList<Integer> arr, int begin, int end){…...

手把手教你用STM32CubeMX配置FOC必备的互补PWM:从中心对齐模式到ADC采样点全解析

STM32CubeMX实战&#xff1a;FOC控制中互补PWM与ADC采样的黄金配置法则 在电机控制领域&#xff0c;磁场定向控制&#xff08;FOC&#xff09;因其卓越的性能表现已成为工业驱动和高精度伺服系统的首选方案。而实现FOC算法的关键硬件基础&#xff0c;便是能够精准输出互补PWM波…...

零基础搞定!全平台 Python + VS Code 开发环境配置保姆级教程

对于刚接触编程的新手来说&#xff0c;编写第一行代码前的“环境配置”往往是最劝退的环节。环境变量是什么&#xff1f;为什么我的终端提示找不到命令&#xff1f;别担心&#xff0c;这篇文章将手把手带你在 Windows、macOS 和 Linux 上搭建目前最流行、最轻量级的开发组合&am…...

深色模式(Dark Mode)适配指南

深色模式适配指南&#xff1a;打造舒适夜间体验 随着移动设备和操作系统的广泛支持&#xff0c;深色模式&#xff08;Dark Mode&#xff09;已成为现代用户界面的重要设计趋势。它不仅能够减少屏幕对眼睛的刺激&#xff0c;还能在低光环境下提升可读性&#xff0c;同时节省设备…...

Audit Log(审计日志)介绍(对系统中关键操作行为记录,用户行为+系统变更+安全事件)中间件 / AOP、数据库层——数据库变更捕获(CDC)

文章目录AuditLog&#xff08;审计日志&#xff09;详解&#xff1a;从概念到实践一、什么是 Audit Log&#xff1f;二、为什么需要审计日志&#xff1f;1. 安全审计与合规要求2. 问题追踪与责任界定3. 内部风险控制三、审计日志 vs 普通日志四、审计日志记录什么&#xff1f;1…...

新加坡ACRA BizFile介绍(新加坡会计与企业监管局Accounting and Corporate Regulatory Authority提供的在线服务平台)

文章目录新加坡ACRA BizFile新加坡ACRA BizFile ACRA BizFile 是新加坡会计与企业监管局&#xff08;Accounting and Corporate Regulatory Authority&#xff0c;简称 ACRA&#xff09;提供的一个在线服务平台。通过 BizFile&#xff0c;用户可以查询和获取新加坡注册公司的公…...

Simulink MinMax模块避坑指南:当uint8遇上int8,仿真结果为何会‘丢1’?

Simulink MinMax模块数据类型陷阱&#xff1a;uint8与int8混合运算的“幽灵减1”现象解析 在嵌入式系统建模领域&#xff0c;Simulink作为行业标准工具链的核心组件&#xff0c;其模块库的稳定性直接关系到数百万工程师的日常开发效率。然而&#xff0c;即使是经过严格验证的基…...

从HTTP协议到XSS攻击:为什么你的Web服务器必须禁用TRACE方法?

从HTTP协议到XSS攻击&#xff1a;为什么你的Web服务器必须禁用TRACE方法&#xff1f; 在Web开发的世界里&#xff0c;安全性往往隐藏在那些看似无害的协议细节中。TRACE方法就像HTTP协议家族中那个被遗忘的成员——它本意善良&#xff0c;却在不经意间成为了攻击者的帮凶。想象…...

如何高效使用LRCGET:离线歌词同步完整指南

如何高效使用LRCGET&#xff1a;离线歌词同步完整指南 【免费下载链接】lrcget Utility for mass-downloading LRC synced lyrics for your offline music library. 项目地址: https://gitcode.com/gh_mirrors/lr/lrcget 你是否曾面对数千首离线音乐&#xff0c;却因缺少…...

金三银四,一个面试官连连夸赞的个人网页技术分享

智能体时代的代码范式转移与 C# 的战略转型 传统的 C# 开发模式&#xff0c;即所谓的“工程导向型”开发&#xff0c;要求开发者创建一个复杂的项目结构&#xff0c;包括项目文件&#xff08;.csproj&#xff09;、解决方案文件&#xff08;.sln&#xff09;、属性设置以及依赖…...

系统故障排查思路

系统故障排查思路&#xff1a;从混乱到有序的解决之道 在数字化时代&#xff0c;系统故障是每个技术团队都可能面临的挑战。无论是服务器宕机、应用程序崩溃&#xff0c;还是网络延迟&#xff0c;这些问题都可能对业务造成严重影响。如何高效、准确地定位并解决故障&#xff0…...

别再傻傻点图标了!用CMD命令玩转Windows远程桌面,效率翻倍(附常用参数清单)

告别图形界面&#xff1a;用命令行玩转Windows远程桌面的高阶技巧 每次连接远程服务器都要重复点击图标、输入地址、调整分辨率&#xff1f;对于需要频繁管理多台设备的运维人员和开发者来说&#xff0c;这种低效操作简直是在浪费生命。今天我要分享的是如何通过CMD命令和批处理…...

基于Halcon视觉技术的PCB元件缺失检测实战指南

1. 为什么选择Halcon进行PCB元件缺失检测 在电子制造业中&#xff0c;PCB&#xff08;印刷电路板&#xff09;的质量控制至关重要。一个缺失的电阻、电容或其他元件可能导致整个电路板无法正常工作。传统的人工目检方式效率低下且容易出错&#xff0c;而Halcon作为工业视觉领域…...

Java8 Stream sorted排序实战:从Comparator基础到多级排序进阶

1. 从零开始理解Stream sorted排序 第一次接触Java8的Stream sorted方法时&#xff0c;我盯着那段链式调用的代码看了足足十分钟。就像刚拿到新手机的老人&#xff0c;明明按键就在眼前&#xff0c;却不知道从哪下手。后来在实际项目中踩过几次坑才明白&#xff0c;sorted()本质…...

DataX 实战:从零构建跨库数据同步解决方案

1. 为什么选择DataX进行跨库数据同步 第一次接触DataX是在处理一个电商平台的订单数据迁移项目。当时需要将MySQL中的3000万条订单数据同步到阿里云的AnalyticDB进行分析&#xff0c;尝试了多种方案后&#xff0c;DataX的表现让我印象深刻。相比传统的SQL导出导入方式&#xff…...

Excel炒股党必备:手把手教你用Power Query免费获取并刷新股票历史数据

Excel炒股党必备&#xff1a;手把手教你用Power Query免费获取并刷新股票历史数据 在投资分析领域&#xff0c;数据更新速度往往决定着决策质量。对于习惯使用Excel的投资者来说&#xff0c;每次手动复制粘贴股票数据不仅效率低下&#xff0c;还容易出错。其实Excel内置的Power…...

管理SELinux安全性知识点问答

1.SELinux是如何保护资源的? SELinux给进程和文件指定了规则&#xff0c;严格按照规则限制文件和进程&#xff0c;默认拒绝所有未明确的操作来保护资源。 2.什么是强制访问控制(MAC)?它有什么特点? 强制访问控制是由系统统一强制决定进程/用户对文件/设备的访问权限。用户和…...

kotlin中一般用高介函数代替return

在 Kotlin 里完全可以不用 break &#xff0c;而且日常开发基本都这么写。 我给你按场景列全&#xff0c;都是实际开发里最常用的替代方案&#xff0c;一看就会。集合高阶函数&#xff08;最常用&#xff0c;直接替代 break&#xff09; 找到第一个满足条件就停&#xff08;等…...

AI编程革命:Codex如何重塑脚本开发效率

技术文章大纲&#xff1a;告别重复造轮子——利用Codex高效编写脚本核心价值与痛点分析重复性脚本开发的低效现状 人工编写脚本的常见问题&#xff1a;语法错误、逻辑冗余、调试耗时 Codex如何通过自然语言理解降低脚本开发门槛Codex基础能力解析自然语言到代码的转换机制 支持…...

Kelsey Hightower在KubeCon 2026:面对AI,人人都是初级工程师

Electrolux站点可靠性产品经理Kristina Kondrashevich清晰地记得Kelsey Hightower对她工作产生的深刻影响。"我们参加了KubeCon 2023&#xff0c;Kelsey Hightower在那次大会上做了一场关于开源项目的演讲&#xff0c;"Kondrashevich告诉The New Stack&#xff0c;&q…...

告别数据焦虑:用MedAugment给你的医学影像数据集‘打鸡血’(附Python实战代码)

告别数据焦虑&#xff1a;用MedAugment给你的医学影像数据集‘打鸡血’&#xff08;附Python实战代码&#xff09; 当你面对只有几十张标注好的医学影像数据时&#xff0c;是否感到无从下手&#xff1f;作为经历过这种困境的开发者&#xff0c;我清楚地记得第一次尝试用200张皮…...

Allegro PCB覆铜设计的10个高效技巧

1. 覆铜基础设置&#xff1a;从零开始的高效起点 刚接触Allegro PCB设计时&#xff0c;我最常犯的错误就是忽略覆铜的基础设置。很多人觉得覆铜就是随便画个形状填满铜皮&#xff0c;但实际工作中&#xff0c;合理的初始设置能节省50%以上的后期修改时间。在Allegro 16.6之后的…...

Sunshine游戏串流技术架构深度解析

Sunshine游戏串流技术架构深度解析 【免费下载链接】Sunshine Self-hosted game stream host for Moonlight. 项目地址: https://gitcode.com/GitHub_Trending/su/Sunshine Sunshine作为开源自托管游戏串流服务器&#xff0c;通过Moonlight协议实现低延迟跨设备游戏共享…...

生成式AI隐私影响评估(PIA)标准化模板(含12项强制审计指标+自动打分系统)

第一章&#xff1a;生成式AI应用数据隐私保护 2026奇点智能技术大会(https://ml-summit.org) 生成式AI在内容创作、代码生成与客户服务等场景中快速落地&#xff0c;但其对训练数据与用户输入的高度依赖&#xff0c;使敏感信息泄露、成员推断&#xff08;membership inference…...

高效处理SDF文件:拆分与分子属性数据清理实战

1. SDF文件基础与化学信息学应用 SDF&#xff08;Structure Data File&#xff09;是化学信息学领域最常用的分子数据存储格式之一。这种纯文本格式最初由MDL公司开发&#xff0c;现已成为药物研发和分子建模中的通用标准。一个典型的SDF文件包含三个核心部分&#xff1a;分子结…...

[具身智能-380]:Habitat仿真平台概述以及如何利用该平台进行模型训练或算法调试?

&#x1f4d8; Habitat 仿真平台详解与训练/调试指南 Habitat 是由 Meta AI (FAIR) 开源的 3D 具身智能仿真平台&#xff0c;专注于室内视觉导航、多模态交互、具身感知与对话式 AI。它在学术界与工业界被广泛用于 Vision-and-Language Navigation (VLN)、ObjectGoal Navigati…...

【独立开发2】- Netunnel 内网穿透软件 - 你也在找无限制、便宜的吗?

设计初衷 总是找不到一款没有限制、便宜、操作简单的内网穿透软件。定价&#xff1a;0.5元/Gb &#xff0c;最低一元。 https://github.com/aifuqiang02/netunnel 下载地址 , 访问不了github 的小伙伴&#xff0c; 可以加QQ群。找群主。 1、软件首页 &#xff08;一睹为快&a…...

2026个人创业项目,0基础做门店WiFi商业变现

2026线下实体店流量红利依旧很大&#xff0c;很多人不知道&#xff0c;门店WiFi其实是一个非常适合个人起步的轻创业项目&#xff0c;不需要门店、不需要人脉、不需要营业执照&#xff0c;个人主体就能直接落地上线。 日常开店的餐饮、棋牌室、宾馆、便利店&#xff0c;几乎每…...

Golang colly爬虫框架如何用_Golang colly教程【进阶】

c.Visit()未触发OnHTML最常见原因是请求被目标站拦截导致403&#xff0c;因Colly默认UA易被拒绝&#xff1b;需设自定义UserAgent、加OnResponse打印状态码、处理重定向、传完整URL、用Limit()控并发、解压gzip、避开JS渲染页、选稳定选择器、用连接池channel安全存库。为什么 …...

安卓应用开发全流程实践与技术要点详解

引言 随着移动互联网的深入发展,安卓操作系统凭借其开放性和庞大的用户基数,在全球移动设备市场占据着举足轻重的地位。这催生了市场对高质量安卓应用和优秀安卓开发工程师的持续需求。作为一名安卓开发工程师,其职责远不止于编写代码,更涉及从需求理解、架构设计、编码实…...