| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> 数据结构与算法 -> 快速排序的三种方法 -> 正文阅读 |
|
[数据结构与算法]快速排序的三种方法 |
目录 1. hoare法快速排序是Hoare于1962年提出的一种二叉树结构的交换排序方法,我们先来介绍的就是他所创建的方法。 方法步骤: 1. 选择数组最左边(最右边)为基准数key 2. 从右边开始(从左边)开始进行筛选,右边(从左边)选出小于key的数 3. 然后从左边(从右边)开始选择出大于key的数 4. 两者进行交换 5. 重复上述循环,直到左边和右边相遇 这里有个难点:为什么选取左边为基准数就要从右边开始寻找? 因为从右边开始可以保证最后相遇处的数是小于key的,这样才满足最终结果:左边都小于key,右边都大于key 代码实现如下:
2.? 挖坑法挖坑法是快速排序的一种更新版。 实现步骤: 1. 以最左边为基准数key,并保留其数据。 2. 可以视基准数的位置空出来了,那从最右边开始寻找小于key的数放置在此坑位上。 3. 当从右边找到合适的数放置左边的坑位时,那右边就多了一个坑位,然后就从左边开始找一个大于key的数放在此坑位。 4. 重复上述步骤,直到最终左边和右边相遇。 代码实现:
?使用了局部变量pit让代码更有可读性,那精简版是什么?
这里舍去了pit变量,代码更加简洁。 3. 前后指针法与挖坑法相同也是一种更新版本。 实现步骤: 1. 使用指针prev指向第一个位置,指针cur指向下一个位置。 2. 当cur所指的数据不小于key时,cur指针后移 3. 当cur所指的数据小于key,prev指针后移并与cur指针进行数据交换,然后cur后移。 4. 重复上述操作,直到cur超出界限。 代码实现如下:
为什么当cur小于key还要保证prev+1!=cur才进行交换呢? 因为当prev紧邻cur时,则说明两个指针之间没有大于key的数据,无需进行自我交换 当prev+1!=cur时,则说明两个指针之间有大于key的数据,当prev+1则找到了大于key的数,跟cur所指小于key的数进行交换则满足了小于key的在左边,大于key的在右边。 直到cur大于right,则说明之后没有小于key的数,则将prev与left进行交换,完成小于key的在左边,大于key的在右边。 |
|
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 | -2025/1/6 17:44:20- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |