我的编程空间,编程开发者的网络收藏夹
学习永远不晚

【Java】快速排序

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

【Java】快速排序

一、什么是快速排序

快速排序是由冒泡排序演变而来,比冒泡排序更快的排序算法。之所以快,是因为快速排序用了分治法

相同的是,与冒泡排序一样,快速排序也属于交换排序,通过元素之间的比较和交换来排序。

不同的是,冒泡排序每一轮只把一个元素冒泡到数列的一端,而快速排序每轮挑选一个基准元素,让比它小的元素移动到一端,让比它大的元素移动到另一端,从而把数列拆解成两个部分

在这里插入图片描述
这种每次将数列分为两个部分的方法就叫做分治法

分治法的好处体现在相比于冒泡排序它会有更小的时间复杂度,对于n的元素的冒泡排序时间复杂度为O(n2),而快速排序总体的平均时间复杂度为O(nlogn)

二、基准元素的选择

在使用分治法的过程中以基准元素为中心把其他元素移到它的两边,那么如何选择基准元素呢?

1、选择第一个元素

最简单的方法是直接选择数列第一个元素为基准元素,但是这种方法在有些特殊情况下会出现问题:

在这里插入图片描述
对于这种原本是逆序的数列,每轮都只能确定基准元素的位置,这种情况下快速排序需要进行n轮,时间复杂度退化到了O(n2)

2、随机选择

为了解决时间复杂度过大的情况,我们可以随机选择一个元素,并与首位元素互换位置,虽然这种情况下也有几率选到数列的最大或最小值,但大多情况下都是可以的。

所以,虽然快速排序的平均时间复杂度为O(nlogn),但最坏情况下也可以达到O(n2)。

三、元素的交换

选好了基准元素,就要将其他元素移到基准元素两边,具体实现有两种方法:

  • 双边循环法
  • 单边循环法

1、双边循环法

对以下数列按从小到大进行排序:
在这里插入图片描述
首先,选定基准元素p,并设置左右两个指针 lr

在这里插入图片描述
开始循环后,从r指针开始,让r指针元素与基准元素做比较,如果大于等于p,则r指针向左移动;如果小于p,则停止移动,换到l指针。

对于当前数列,r指针元素为1,1<4,所以r指针停止移动,换到l指针。

换到l指针后,让l指针元素与基准元素做比较,如果小于等于p,则r指针向右移动;如果大于p,则停止移动

按照此思路,后续步骤如下:

在这里插入图片描述
实现代码如下:

import java.util.Arrays;public class quickSort {    public static void quickSort(int arr[],int startIndex,int endIndex){        //递归结束条件为startIndex大于或等于endIndex        if(startIndex>=endIndex){            return;        }        //得到基准元素位置        int pIndex=partition(arr,startIndex,endIndex);        //根据基准元素分两部分进行递归排序        quickSort(arr,startIndex,pIndex-1);        quickSort(arr,pIndex+1,endIndex);    }        public static int partition(int arr[],int startIndex,int endIndex)    {        int p=arr[startIndex];//基准元素(可取随机位置)        int l=startIndex;//左指针        int r=endIndex;//右指针        while(l!=r){            //控制右指针向左移动,找到小于基准元素的那个数            while((lp)){                r--;            }            //控制左指针向右移动,找到大于基准元素的那个数            while((l                l++;            }            //交换l指针和r指针所指的元素            if(l                int tmp=arr[l];                arr[l]=arr[r];                arr[r]=tmp;            }        }        //交换基准元素和重合点的元素        arr[startIndex]=arr[l];        arr[l]=p;        return l;    }    public static void main(String[] args) {        int arr[]={4,7,6,5,3,2,8,1};        quickSort(arr,0,7);        System.out.println(Arrays.toString(arr));    }}

在这里插入图片描述

2、单边循环法

双边循环更加直观,但代码比较麻烦,而单边循环法从数列的一边对元素进行遍历交换。

开始循环选定基准元素p,再设置一个mark指针指向数列起始位置,mark代表着小于基准元素区域的右边界。

从基准元素的下一位开始遍历,若元素大于基准元素,则继续往后遍历。如果小于基准元素,先将mark指针右移一位,然后将最新遍历的元素与基准元素交换

在这里插入图片描述

单边循环法与双边循环法主要是partition函数的实现不一样

    public static int partition(int arr[],int startIndex,int endIndex)    {        int p=arr[startIndex];//基准元素(可取随机位置)        int mark=startIndex;        for(int i=startIndex+1;i<=endIndex;i++){            if(arr[i]                mark++;                int tmp=arr[mark];                arr[mark]=arr[i];                arr[i]=tmp;            }        }        //交换基准元素和mark指针的元素        arr[startIndex]=arr[mark];        arr[mark]=p;        return mark;    }

可以看出,单边循环法只需要一个循环即可,比双边循环法要简单很多。

在这里插入图片描述

来源地址:https://blog.csdn.net/zcxyywd/article/details/131024516

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

【Java】快速排序

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

【Java】快速排序

文章目录 一、什么是快速排序二、基准元素的选择1、选择第一个元素2、随机选择 三、元素的交换1、双边循环法2、单边循环法 一、什么是快速排序 快速排序是由冒泡排序演变而来,比冒泡排序更快的排序算法。之所以快,是因为快速排
2023-08-17

快速掌握java排序算法-快速排序(图文)

概念快速排序属于交换排序,主要步骤是使用基准元素进行比较,把小于基准元素的移动到一边,大于基准元素的移动到另一边。从而把数组分成两部分,然后再从这两部分中选取出基准元素,重复上面的步骤。过程如下:(推荐视频:java视频教程) 紫色:基准元素绿色:大于基准元
快速掌握java排序算法-快速排序(图文)
2017-05-20

Java中的快速排序

快速排序的原理快速排序是对冒泡排序的一种改进,冒泡排序是通过一个个比较,从而将小的值放在一端,而大的值放在另外一端,从而达到排序的目的。而快速排序,是先选定一个临界值,将比这临界值小的值放在一端,而比临界值大的值放在另外一端。重复上一段方法,可以把已经通过临界
Java中的快速排序
2020-02-07

Java的堆排序、快速排序、归并排序怎么实现

本文小编为大家详细介绍“Java的堆排序、快速排序、归并排序怎么实现”,内容详细,步骤清晰,细节处理妥当,希望这篇“Java的堆排序、快速排序、归并排序怎么实现”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。堆排序
2023-06-26

Java归并排序和快速排序怎么实现

本篇内容介绍了“Java归并排序和快速排序怎么实现”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!归并排序// 归并排序 public
2023-06-04

java中快速排序法是什么

这篇文章将为大家详细讲解有关java中快速排序法是什么,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。快速排序法:顾名思议,快速排序法是实践中的一种快速的排序算法,在c++或对java基本类型的排序中特别有
2023-06-29

java中如何实现快速排序

下面由java入门学习栏目为大家介绍java中如何实现快速排序,希望这种算法排序可以帮助到大家!快速排序的时间复杂度并不固定,如果在最坏情况下(在一个原本逆向排序的数列中选择第一个元素为基准元素)速度比较慢,达到 O(n^2)(和选择排序一个效率),但是如果在
java中如何实现快速排序
2018-05-13

Java实现快速排序和堆排序的示例代码

这篇文章主要为大家详细介绍了快速排序和堆排序的多种语言的实现(JavaScript、Python、Go语言、Java、C++),感兴趣的小伙伴可以了解一下
2022-12-22

Java快速排序方法怎么使用

本篇内容介绍了“Java快速排序方法怎么使用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!快速排序思想介绍快速排序使用了分治的思想,通过一轮
2023-06-02

Java排序算法怎么快速上手

本篇内容主要讲解“Java排序算法怎么快速上手”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Java排序算法怎么快速上手”吧!插入排序插入排序的基本思想:每步将一个待排序元素,按其排序码大小插入
2023-06-27

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录