一分钟快速排序

2024-05-23 22:12
文章标签 快速 排序 一分钟

本文主要是介绍一分钟快速排序,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

这个 quick_sort 函数是一个实现快速排序(Quicksort)算法的递归函数。快速排序是一种高效的排序算法,通常用于对大规模数据集进行排序。以下是对该函数的详细解释:

函数签名

void quick_sort(int q[], int l, int r)
  • q[]:要排序的数组。
  • l:数组的左边界索引。
  • r:数组的右边界索引。

基本思想

快速排序的基本思想是通过选择一个"基准"元素,将数组划分为两个子数组,使得左子数组中的所有元素都小于基准元素,右子数组中的所有元素都大于基准元素。然后递归地对两个子数组进行排序。

函数具体步骤

  1. 终止条件

    if (l >= r) return;
    

    如果左边界大于或等于右边界,说明子数组的长度为0或1,此时已经是有序的,直接返回。

  2. 初始化指针和基准元素

    int i = l - 1, j = r + 1, x = q[l + r >> 1];
    
    • ij 分别初始化为左边界的前一个位置和右边界的后一个位置。
    • x 是基准元素,通常选择中间位置的元素(这里使用 (l + r) >> 1 计算中间位置并作为基准)。
  3. 划分过程

    while (i < j)
    {do i ++ ; while (q[i] < x);do j -- ; while (q[j] > x);if (i < j) swap(q[i], q[j]);
    }
    
    • i 向右移动,直到找到一个不小于基准元素的元素。
    • j 向左移动,直到找到一个不大于基准元素的元素。
    • 如果 i 小于 j,则交换 q[i]q[j]
  4. 递归调用

    quick_sort(q, l, j), quick_sort(q, j + 1, r);
    
    • 对左子数组 q[l..j] 进行递归排序。
    • 对右子数组 q[j + 1..r] 进行递归排序。

代码解释

void quick_sort(int q[], int l, int r)
{if (l >= r) return;int i = l - 1, j = r + 1, x = q[l + r >> 1];while (i < j){do i ++ ; while (q[i] < x);do j -- ; while (q[j] > x);if (i < j) swap(q[i], q[j]);}quick_sort(q, l, j), quick_sort(q, j + 1, r);
}
  • if (l >= r) return;:递归终止条件。如果子数组长度为0或1,直接返回。
  • int i = l - 1, j = r + 1, x = q[l + r >> 1];:初始化左右指针和基准元素。
  • while (i < j):进入划分循环。
    • do i ++ ; while (q[i] < x);i 向右移动,直到找到一个不小于 x 的元素。
    • do j -- ; while (q[j] > x);j 向左移动,直到找到一个不大于 x 的元素。
    • if (i < j) swap(q[i], q[j]);:如果 i 小于 j,交换 q[i]q[j]
  • quick_sort(q, l, j), quick_sort(q, j + 1, r);:递归排序左、右子数组。

示例

假设输入数组为 [3, 6, 8, 10, 1, 2, 1],调用 quick_sort(q, 0, 6)

  1. 初始基准元素为中间值 8,通过划分将数组变为 [3, 6, 1, 1, 2, 8, 10]8 左边是小于 8 的元素,右边是大于 8 的元素。
  2. 递归对左子数组 [3, 6, 1, 1, 2] 和右子数组 [10] 进行排序。
  3. 最终得到排序后的数组 [1, 1, 2, 3, 6, 8, 10]

快速排序是一种高效的排序算法,平均时间复杂度为 O(n log n),但在最坏情况下(如输入已经有序时)时间复杂度为 O(n^2)。通过合理选择基准元素,可以在很大程度上避免最坏情况。

测试代码

#include <iostream>
#include <algorithm>
using namespace std;void quick_sort(int q[], int l, int r)
{if (l >= r)return;int i = l - 1, j = r + 1, x = q[l + r >> 1];while (i < j){doi++;while (q[i] < x);doj--;while (q[j] > x);if (i < j)swap(q[i], q[j]);}quick_sort(q, l, j), quick_sort(q, j + 1, r);
}int main()
{int q[] = {3, 6, 2, 1, 7, 4, 5};quick_sort(q, 0, 6);for (int i = 0; i < 7; i++)cout << q[i] << ' ';return 0;
}

这篇关于一分钟快速排序的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


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

相关文章

MybatisX快速生成增删改查的方法示例

《MybatisX快速生成增删改查的方法示例》MybatisX是基于IDEA的MyBatis/MyBatis-Plus开发插件,本文主要介绍了MybatisX快速生成增删改查的方法示例,文中通过示例代... 目录1 安装2 基本功能2.1 XML跳转2.2 代码生成2.2.1 生成.xml中的sql语句头2

8种快速易用的Python Matplotlib数据可视化方法汇总(附源码)

《8种快速易用的PythonMatplotlib数据可视化方法汇总(附源码)》你是否曾经面对一堆复杂的数据,却不知道如何让它们变得直观易懂?别慌,Python的Matplotlib库是你数据可视化的... 目录引言1. 折线图(Line Plot)——趋势分析2. 柱状图(Bar Chart)——对比分析3

一文教你Java如何快速构建项目骨架

《一文教你Java如何快速构建项目骨架》在Java项目开发过程中,构建项目骨架是一项繁琐但又基础重要的工作,Java领域有许多代码生成工具可以帮助我们快速完成这一任务,下面就跟随小编一起来了解下... 目录一、代码生成工具概述常用 Java 代码生成工具简介代码生成工具的优势二、使用 MyBATis Gen

Java List排序实例代码详解

《JavaList排序实例代码详解》:本文主要介绍JavaList排序的相关资料,Java排序方法包括自然排序、自定义排序、Lambda简化及多条件排序,实现灵活且代码简洁,文中通过代码介绍的... 目录一、自然排序二、自定义排序规则三、使用 Lambda 表达式简化 Comparator四、多条件排序五、

JAVA数组中五种常见排序方法整理汇总

《JAVA数组中五种常见排序方法整理汇总》本文给大家分享五种常用的Java数组排序方法整理,每种方法结合示例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录前言:法一:Arrays.sort()法二:冒泡排序法三:选择排序法四:反转排序法五:直接插入排序前言:几种常用的Java数组排序

使用animation.css库快速实现CSS3旋转动画效果

《使用animation.css库快速实现CSS3旋转动画效果》随着Web技术的不断发展,动画效果已经成为了网页设计中不可或缺的一部分,本文将深入探讨animation.css的工作原理,如何使用以及... 目录1. css3动画技术简介2. animation.css库介绍2.1 animation.cs

SpringBoot快速搭建TCP服务端和客户端全过程

《SpringBoot快速搭建TCP服务端和客户端全过程》:本文主要介绍SpringBoot快速搭建TCP服务端和客户端全过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,... 目录TCPServerTCPClient总结由于工作需要,研究了SpringBoot搭建TCP通信的过程

一文教你Python如何快速精准抓取网页数据

《一文教你Python如何快速精准抓取网页数据》这篇文章主要为大家详细介绍了如何利用Python实现快速精准抓取网页数据,文中的示例代码简洁易懂,具有一定的借鉴价值,有需要的小伙伴可以了解下... 目录1. 准备工作2. 基础爬虫实现3. 高级功能扩展3.1 抓取文章详情3.2 保存数据到文件4. 完整示例

快速修复一个Panic的Linux内核的技巧

《快速修复一个Panic的Linux内核的技巧》Linux系统中运行了不当的mkinitcpio操作导致内核文件不能正常工作,重启的时候,内核启动中止于Panic状态,该怎么解决这个问题呢?下面我们就... 感谢China编程(www.chinasem.cn)网友 鸢一雨音 的投稿写这篇文章是有原因的。为了配置完

Python利用ElementTree实现快速解析XML文件

《Python利用ElementTree实现快速解析XML文件》ElementTree是Python标准库的一部分,而且是Python标准库中用于解析和操作XML数据的模块,下面小编就来和大家详细讲讲... 目录一、XML文件解析到底有多重要二、ElementTree快速入门1. 加载XML的两种方式2.