快速排序总结

标准模版

交换法

单函数法

public static void quickSort(int[] arr, int start, int end) {if (start >= end) {return;}int idx = start;int pivot = arr[idx];int left = start, right = end;while (left < right) {while (left < right && arr[right] >= pivot) {right--;}while(left < right && arr[left] <= pivot) {left++;}swap(arr, left, right);}// 从此行开始,left == rightswap(arr, idx, left);if (start < left) {quickSort(arr, start, left - 1);}if (right < end) {quickSort(arr, right + 1, end);}
}

双函数法

/*** 快速排序* <p>* 这一层的逻辑基本不会变,注意递归退出条件** @param nums* @param start* @param end*/
public static void quickSort(int[] nums, int start, int end) {if (start < end) {int index = partition(nums, start, end);quickSort(nums, start, index - 1);quickSort(nums, index + 1, end);}
}/*** 交换法,即Hoare法** @param arr* @param start* @param end* @return*/
public static int partition(int[] arr, int start, int end) {int index = start;int pivot = arr[index];int left = start, right = end;while (left < right) {// 让right找比pivot小的数while (right > left && arr[right] >= pivot) {right--;}// 让left找比pivot大的数while (left < right && arr[left] <= pivot) {left++;}// 让left与right这两个数进行交换swap(arr, left, right);}// 将基准值放到合适的位置swap(arr, index, left);// 返回基准下标return left;
}private static void swap(int[] nums, int left, int right) {int tmp = nums[left];nums[left] = nums[right];nums[right] = tmp;
}

填坑法

【推荐】单函数法

代码量最少,且不需要swap函数;

public static void quickSort(int[] arr, int start, int end) {if (start >= end) {return;}int idx = start;int pivot = arr[idx];int left = start, right = end;while (left < right) {while (left < right && arr[right] >= pivot) {right--;}arr[left] = arr[right];while(left < right && arr[left] <= pivot) {left++;}arr[right] = arr[left];}// 从此行开始,left == rightarr[left] = pivot;if (start < left) {quickSort(arr, start, left - 1);}if (right < end) {quickSort(arr, right + 1, end);}
}

双函数法

/*** 快速排序* <p>* 这一层的逻辑基本不会变,注意递归退出条件** @param nums* @param start* @param end*/
public static void quickSort(int[] nums, int start, int end) {if (start < end) {int index = partition(nums, start, end);quickSort(nums, start, index - 1);quickSort(nums, index + 1, end);}
}/*** 填坑法** @param arr* @param start* @param end* @return*/
public static int partition(int[] arr, int start, int end) {int index = start;int pivot = arr[index];int left = start, right = end;while (left < right) {// 找到一个比基准小的值while (left < right && arr[right] >= pivot) {right--;}// 放到左边arr[left] = arr[right];// 找到一个比基准大的值while (left < right && arr[left] <= pivot) {left++;}// 放到右边arr[right] = arr[left];}// 基准放到位置上arr[left] = pivot;return left;
}

参考文档

快速排序(三)——hoare法

https://blog.csdn.net/fax_player/article/details/135719674

快速排序(四)——挖坑法,前后指针法与非递归

https://blog.csdn.net/fax_player/article/details/135750747

七大排序算法——快速排序,通俗易懂的思路讲解与图解(完整Java代码)

https://blog.csdn.net/The_emperoor_man/article/details/131706776

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/32295.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

VB.net-提取视频中音频

如果想用VB.NET开发一个提取视频中的音频这样的程序,需要使用到媒体处理库,比如NAudio或者FFmpeg。FFmpeg是一个功能强大的开源媒体处理库,支持多种媒体格式,并提供了丰富的命令行工具和库接口。 下面是一个使用FFmpeg命令行工具从视频中提取音频的VB.NET示例程序。 首先…

rockchip linux sdk指定编译配置文件

SDK&#xff1a;rk3568_linux4.19_V1.4.0 硬件平台&#xff1a;RK3566 一、指定板级配置文件 板级配置文件在<SDK>/device/rockchip/rk3566_rk3568目录下。 1、方法1 ./build.sh后⾯加上板级配置⽂件&#xff0c;例如&#xff1a; ./build.sh /device/rockchip/rk3…

es深分页问题解决小记

SpringBoot整合SpringDataElasticsearch ElasticsearchRestTemplate使用 ElasticSearch的scroll滚动查询以及在Springboot中的使用 ES三种查询 问题描述 在分页查询中&#xff0c;当查询数据总量超过10000时&#xff0c;es为了避免大量数据加载到内存导致内存溢出默认情况下…

vmware虚拟机安装ubuntu20.04

1.下载Ubuntu 20.04的ISO镜像 Index of /ubuntu-releases/ 2.安装VMware 3.创建新的虚拟机&#xff1a;打开VMware&#xff0c;选择“创建新的虚拟机”或通过文件菜单新建虚拟机。 4.选择典型&#xff0c;然点点击下一步&#xff1a; 5.选择稍后安装操作系统&#xff1a; 6.…

密码学及其应用 —— 密码学概述

1 安全属性和机制 1.1 基本概念 1.1.1 三个核心概念 在讨论信息安全时&#xff0c;我们通常会谈到三个核心概念&#xff1a;保密性、完整性和可用性。这三个概念共同构成了信息安全的基础。 保密性&#xff1a;指的是确保信息只能被授权的人员访问。这就意味着信息在存储、传…

jnp.diag

jnp.diag 是 JAX 库中用于创建对角矩阵或提取对角线元素的函数。具体功能取决于输入的形状&#xff1a; 当输入是一维数组时&#xff0c;jnp.diag 创建一个以该数组为对角线元素的对角矩阵。当输入是二维数组时&#xff0c;jnp.diag 提取并返回对角线元素。 函数签名 jnp.di…

【软件工程】【22.04】p1

关键字&#xff1a; 软件需求规约基本性质、数据字典构成、内聚程度最高功能内聚、公有属性、RUP实体类、评审、测试序列、软件确认过程、CMMI能力等级 软件需求分类、DFD数据流图组成&#xff08;实体&#xff09;、经典详细设计、数据耦合、关联多重性、状态图、黑盒测试、…

【LinuxC语言】进程间的通信——管道

文章目录 前言不同进程间通信的方式管道匿名管道和命名管道半双工与全双工管道相关函数创建管道总结前言 在Linux操作系统中,进程是执行中的程序的实例。每个进程都有自己的地址空间,数据栈以及其他用于跟踪进程执行的辅助数据。操作系统管理这些进程,并通过调度算法来分享…

设计模式——设计模式原则

设计模式 设计模式示例代码库地址&#xff1a; https://gitee.com/Jasonpupil/designPatterns 设计模式原则 单一职责原则&#xff08;SPS&#xff09;&#xff1a; 又称单一功能原则&#xff0c;面向对象五个基本原则&#xff08;SOLID&#xff09;之一 原则定义&#xf…

tinyxml

github下载相关的软件包&#xff0c;其中有四个文件需要主要需要关注就是分别是tinyxml12.cpp&#xff0c;tinyxml12.h&#xff0c;rss网页xml文件&#xff0c;还有就是官方给的test文件tinyxmltest.cpp。 example1就是提供一个打开文件的方式 int example_1() {XMLDocument …

方法区讲解

栈、堆、方法区三者之间的关系如上图所示&#xff0c; 第一个Student代表类型&#xff0c;存放在方法区中&#xff0c; student 变量是在虚拟机栈中&#xff0c;最后 new 出来的Student对象放在堆中。本篇主要讲一下有关方法区中的知识。 文章目录 概念方法区的内部结构方法区的…

6.25世界白癜风日·成都博润白癜风医院获评“成都市医学重点专科”

夏日热情如江潮&#xff0c;勇攀高峰正当时。为激发新质生产力&#xff0c;驱动学术研究引领医院发展&#xff0c;也为了迎接 6.25 世界白癜风日。 6月22日&#xff0c;成都博润白癜风医院隆重举行成都市医学重点专科授牌新闻发布会暨成都市市级继续医学教育项目《难治性白癜风…

Cesium总目录

文章目录 Cesium全家桶总目录1 MyCesiumJS Basic1.1 使用Vite搭建开发环境1.2 加载在线瓦片地图数据1.3 加载离线地图数据1.4 加载多种格式外部数据1.5 卫星云图轮播1.6 浏览器控制台查看位置角度 2 MyCesiumJS Pro2.1 空间碎片2.2 变色龙2.3 万家灯火2.4 火星2.5 变色龙II2.6 …

LeetCode——判断回文数

给你一个整数 x &#xff0c;如果 x 是一个回文整数&#xff0c;返回 true &#xff1b;否则&#xff0c;返回 false 。 回文数是指正序&#xff08;从左向右&#xff09;和倒序&#xff08;从右向左&#xff09;读都是一样的整数。 例如&#xff0c;121 是回文&#xff0c;而 …

【招聘贴】JAVA后端·唯品会·BASE新加坡

作者|老夏&#xff08;题图&#xff1a;公司业务介绍页&#xff09; “ 请注意&#xff0c;这两个岗是BASE新加坡的&#xff0c;欢迎推荐给身边需要的朋友&#xff08;特别是在新加坡的&#xff09;。” VIP海外业务-产品技术团队&#xff0c;这两个岗位属于后端工程组的岗&…

每日待办事项提醒用什么便签app比较好?

在快节奏的现代生活中&#xff0c;我们经常需要记住各种事项&#xff0c;如会议、预约、购物清单等。这时&#xff0c;一个高效的便签App就显得尤为重要&#xff0c;可以帮助我们有效地管理日常任务和待办事项。而每日待办事项提醒用什么便签app比较好&#xff1f;面对市场上众…

C++程序设计基础实践:学生信息管理系统

目录 1 系统介绍 2 系统设计 3 设计结果 4 源代码 近来有空闲&#xff0c;把前几个学期做的实验上传上来。如有错误的地方欢迎大佬批评指正&#xff0c;有更好的方法也期待您的分享~ 实验要求 本课程要完成一个学生信息管理系统的设计与实现&#xff0c;可实现对于学生信息…

“三巫日”大结局:标普500尾盘成交量飙升,英伟达“过山车”终以下跌收盘

内容提要 隔夜“美股三巫日”&#xff0c;美国证券交易所迎来了180亿股的换手&#xff0c;较过去三个月的平均水平激增55%&#xff0c;标普500尾盘成交量比平日激增30%。在周五到期的5.5万亿美元各类证券衍生品里&#xff0c;与英伟达相关的衍生品合约价值高居第二&#xff0c…

upload-labs实验过程中遇到的问题

第6题问题&#xff1a;500异常码 发现500异常码&#xff0c;这个应该是apache版本问题&#xff0c;可更换其他版本&#xff0c;或者更换为nginx 12题问题&#xff1a;上传出错 出现上传错误&#xff0c;大概率是php版本问题&#xff0c;需要下载php5.2.17版本的php或者更换其他…

编程书籍的枯燥真相:你也有同样的感受吗?

讲动人的故事,写懂人的代码 我得实话实说,你可能已经发现市面上的大部分编程入门书籍有些枯燥。这个问题的根源在于许多作者把本应该充满乐趣和吸引力的入门指南,写得就像一本沉闷的参考手册。这就好比把一本充满冒险和乐趣的旅行日记,写成了一本单调乏味的字典。 我完全理…