news 2026/6/26 17:23:48

算法-排序-10

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
算法-排序-10

力扣-真题-排序数组


没啥好说的,排序可以说是最基础的算法题了, 考基本功, 经常面试的笔试题都会让手写 排序。
咱们就从最基础的冒泡排序开始讲。
冒泡排序的 排序逻辑 是 每一次遍历 都把 数组中最大的元素 放在最后。
假如 数组长度是n
那么第一次遍历, 就把数组区间为0~ n-1 的最大数字 放在 n-1 位 (索引从0开始)
第二次 ,就把数组区间为0~ n-2 的最大数字 放在 n -2 位
一直到倒数第二次遍历, 把数组区间在0~ 1 的 最大的数字放在第二位,
此时就已经排好序了。
至于 针对 每一个区间 怎么把 最大的数字 放在最后,比如针对数组区间是0 ~ n -1 , 冒泡排序的方法是, 从0开始遍历到 n-2 , 每一次遍历 ,都让 nums[i] 跟 nums[i+1]对比, 让 大的那个数 占据 nums[i+1],到最后 n-2次遍历, 自然 nums[n-2]就是最大了。

publicint[]sortArray(int[]nums){intn=nums.length-1;// -1是因为其实遍历n-1次就够了for(inti=0;i<n;i++){for(intj=0;j<n-i;j++){if(nums[j]>nums[j+1]){swap(j,j+1,nums);}}}returnnums;}publicvoidswap(intx,inty,int[]nums){inttem=nums[x];nums[x]=nums[y];nums[y]=tem;}

接着就是快速排序。
冒泡排序的 无序区间 是 一点点 减少的。 在数据量有点大的时候, 比如说 100 个数 , 可能需要 比较 接近百万次。
快速排序则采用了 分而治之 的思想, 取 区间 中的第一个数作为基准,
将 区间 划分成两个 更小的区间, 所以 遍历一次, 就能将 100个数字的排序问题, 可能降级两个为 50个 数字 的区间 排序, 然后 再遍历两次 (对两个50区间遍历), 可能就降级为 4 个 25个数字的 区间排序,
随着遍历的继续, 区间数量可能变多, 但是 区间的长度在 断崖式的下降, 8 -》 4 -》 2 -》 1 ,你只要想想 100个数字 一直用冒泡排序 可能需要比较 10000次, 毕竟时间复杂度是O(n^2), 但是在遍历了4次 后最多比较 400次, 加上, 剩下4个 25个数的区间 都用冒泡排序, 一个25区间是 25的平方 225 次, 4次加一起也就 900次比较, 加上400,也就1300次,对比 10000 少了将近 9000次比较。 就可以初见端倪。 更不用说一直用 快速排序 的 分而治之 方法排序。

publicint[]sortArray(int[]nums){sort(0,nums.length-1,nums);returnnums;}publicvoidsort(intleft,intright,int[]nums){if(left>=right)return;// 选择最右边的元素作为基准值intpivot=nums[right];intleftIndex=left;intrightIndex=right-1;while(leftIndex<=rightIndex){// 从左往右找第一个大于等于基准数的数字while(leftIndex<=rightIndex&&nums[leftIndex]<pivot){leftIndex++;}// 从右往左找第一个小于基准数的数字while(leftIndex<=rightIndex&&nums[rightIndex]>pivot){rightIndex--;}// 只有当左指针仍在右指针左侧时才交换if(leftIndex<rightIndex){swap(leftIndex,rightIndex,nums);leftIndex++;rightIndex--;}else{// 退出循环条件break;}}// 将基准值放到正确位置swap(leftIndex,right,nums);// 递归排序左右子数组sort(left,leftIndex-1,nums);sort(leftIndex+1,right,nums);}publicvoidswap(intx,inty,int[]nums){inttemp=nums[x];nums[x]=nums[y];nums[y]=temp;}
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/26 22:52:38

K8S-namespace资源对象

一、概述 Kubernetes 支持多个虚拟集群&#xff0c;它们底层依赖于同一个物理集群。 这些虚拟集群被称为命名空间。命名空间namespace是k8s集群级别的资源&#xff0c;可以给不同的用户、租户、环境或项目创建对应的命名空间&#xff0c;例如&#xff0c;可以为test、devlopmen…

作者头像 李华
网站建设 2026/6/26 3:05:19

K8S-Service资源对象

一、概述 在kubernetes中&#xff0c;pod是应用程序的载体&#xff0c;我们可以通过pod的ip来访问应用程序&#xff0c;但是pod的ip地址不是固定的&#xff0c;这也就意味着不方便直接采用pod的ip对服务进行访问。 为了解决这个问题&#xff0c;kubernetes提供了Service资源&…

作者头像 李华
网站建设 2026/6/26 10:10:02

郭嘉队动手了?刺激消费扩大内需!

一&#xff0c;沪指新低砸出双底&#xff01;3800 点大胆布局&#xff0c;越跌越买正当时上证指数创了新低&#xff0c;从时间和空间两个维度看&#xff0c;这就是双底形态的第二只脚在落地&#xff0c;市场正在慢慢构筑底部。尐程序&#xff1a;期权汇之前大盘回升的时候&…

作者头像 李华
网站建设 2026/6/26 16:44:07

记力扣2105.给植物浇水 练习有感

Alice 和 Bob 打算给花园里的 n 株植物浇水。植物排成一行&#xff0c;从左到右进行标记&#xff0c;编号从 0 到 n - 1 。其中&#xff0c;第 i 株植物的位置是 x i 。每一株植物都需要浇特定量的水。Alice 和 Bob 每人有一个水罐&#xff0c;最初是满的 。他们按下面描述的方…

作者头像 李华
网站建设 2026/6/25 17:47:06

突破性智能容器管理:自托管服务器的革命性演进

突破性智能容器管理&#xff1a;自托管服务器的革命性演进 【免费下载链接】Cosmos-Server ☁️ The Most Secure and Easy Selfhosted Home Server. Take control of your data and privacy without sacrificing security and stability (Authentication, anti-DDOS, anti-bot…

作者头像 李华
网站建设 2026/6/26 6:57:04

超越Borel:论非Borel集的存在性、构造及其在实分析中的核心作用

摘要&#xff1a;在标准拓扑空间&#xff08;如ℝⁿ&#xff09;中&#xff0c;Borel集构成了由开集生成的σ-代数&#xff0c;是实分析、测度论与拓扑学中研究的基本对象。然而&#xff0c;Borel集并未穷尽所有可能的子集&#xff1b;存在大量复杂程度更高、结构更丰富的非Bor…

作者头像 李华