一道快速排序题的解析

本文涉及的产品
全局流量管理 GTM,标准版 1个月
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
云解析 DNS,旗舰版 1个月
简介: 关键码序列(Q,H,C,Y,Q,A,M,S,R,D,F,X),要按照关键码值递增的次序进行排序,若采用以第一个元素为分界元素的快速排序法,则扫描一趟的结果是 ()。

关键码序列(Q,H,C,Y,Q,A,M,S,R,D,F,X),要按照关键码值递增的次序进行排序,若采用以第一个元素为分界元素的快速排序法,则扫描一趟的结果是 ()。


分析:

快速排序的分割策略之一就是,首先用一个临时变量对首元素(轴元素)进行备份,取两个指针left和right。他们的初始值分别是待排序列两端的下标,其中left指向序列最左边的下标,right指向序列最右边的下标。在整个排序过程中保证left不大于right,用下面的方法不断移动指针:

1、首先从right所指的位置向左搜索,找到第一个小于或者等于轴的元素,把这个元素移动到left的位置;

2、再从left所指的位置向右搜索,找到第一个大于轴的元素,把这个元素移动到right的位置;

3、重复上述过程,直到left=right;

4、最后把轴元素放在left所指的位置。


按照上面的方法,对应本题,解题过程如下:
1、初始时,left、right指针指向如下图所示:

这里写图片描述

2、right指针向左搜索,当遇到F时,由于F小于轴值Q,所以把F移动到left指针所指位置:

这里写图片描述

3、left指针向右搜索,当遇到Y时,由于Y大于轴值Q,所以把Y移动到right指针所指位置:

这里写图片描述

4、right指针向左搜索,当遇到D时,由于D小于轴值Q,所以把D移动到left指针所指位置:

这里写图片描述

5、left指针向右搜索,当遇到S时,由于S大于轴值Q,所以把S移动到right指针所指位置:

这里写图片描述

6、此时,left=right,于是把轴元素Q放到left指针此时所指位置上:

这里写图片描述

整个过程如下图所示:

排序过程

参考答案: FHCDQAMQRSYX

相关文章
|
人工智能 算法 搜索推荐
快速排序,分治法实际应用(含码源与解析)
快速排序,分治法实际应用(含码源与解析)
|
编解码 算法 网络协议
【算法基础】快速排序解析
快速排序是一种分治排序方法,通过多次比较和交换来实现排序,其基本操作是将无序表不断拆分和交换,直到拆分到最小时,整个表就成为了一个有序表,从而得到一个新的、记录数量增1的有序表。
113 0
【算法基础】快速排序解析
|
算法 C#
【愚公系列】2021年11月 C#版 数据结构与算法解析(交换排序-快速排序)
【愚公系列】2021年11月 C#版 数据结构与算法解析(交换排序-快速排序)
102 0
【愚公系列】2021年11月 C#版 数据结构与算法解析(交换排序-快速排序)
|
22天前
|
监控 网络协议 Java
Tomcat源码解析】整体架构组成及核心组件
Tomcat,原名Catalina,是一款优雅轻盈的Web服务器,自4.x版本起扩展了JSP、EL等功能,超越了单纯的Servlet容器范畴。Servlet是Sun公司为Java编程Web应用制定的规范,Tomcat作为Servlet容器,负责构建Request与Response对象,并执行业务逻辑。
Tomcat源码解析】整体架构组成及核心组件
|
1月前
|
存储 NoSQL Redis
redis 6源码解析之 object
redis 6源码解析之 object
55 6
|
7天前
|
存储 缓存 Java
什么是线程池?从底层源码入手,深度解析线程池的工作原理
本文从底层源码入手,深度解析ThreadPoolExecutor底层源码,包括其核心字段、内部类和重要方法,另外对Executors工具类下的四种自带线程池源码进行解释。 阅读本文后,可以对线程池的工作原理、七大参数、生命周期、拒绝策略等内容拥有更深入的认识。
什么是线程池?从底层源码入手,深度解析线程池的工作原理
|
11天前
|
开发工具
Flutter-AnimatedWidget组件源码解析
Flutter-AnimatedWidget组件源码解析
|
7天前
|
设计模式 Java 关系型数据库
【Java笔记+踩坑汇总】Java基础+JavaWeb+SSM+SpringBoot+SpringCloud+瑞吉外卖/谷粒商城/学成在线+设计模式+面试题汇总+性能调优/架构设计+源码解析
本文是“Java学习路线”专栏的导航文章,目标是为Java初学者和初中高级工程师提供一套完整的Java学习路线。
|
29天前
|
测试技术 Python
python自动化测试中装饰器@ddt与@data源码深入解析
综上所述,使用 `@ddt`和 `@data`可以大大简化写作测试用例的过程,让我们能专注于测试逻辑的本身,而无需编写重复的测试方法。通过讲解了 `@ddt`和 `@data`源码的关键部分,我们可以更深入地理解其背后的工作原理。
25 1

推荐镜像

更多