排序算法——快速排序

一、介绍

快速排序是使用"分而治之"的方式进行排序,会先再数据中找到一个虚拟的中间值,一般选取第一个值作为中间值,并按此中间值将所有要排序的数值分成两个部分,其中小于中间值的数据放在左边,大于中间值的数据放在右边,再以同样的方式将两边的数据再进行分割找一个中间值,大的放左边,小的放右边, 不断重复此过程,直到数据有序为止。

演示:

用一个恰好是中间的值作为第一个值方便演示

视频演示:

快速排序更多实用攻略教学,爆笑沙雕集锦,你所不知道的游戏知识,热门游戏视频7*24小时持续更新,尽在哔哩哔哩bilibili 视频播放量 25、弹幕量 0、点赞数 0、投硬币枚数 0、收藏人数 0、转发人数 0, 视频作者 浅陌95sss, 作者简介 记录自己的学习成果,分享自己的快乐,相关视频:冒泡排序演示,选择排序演示,排行榜模拟,学习记录--BFS寻路算法,直接插入排序演示,学习记录--设计模式之命令模式,希尔排序,学习记录--循环列表,学习记录--Rpg雷达图,简单的同步Demohttps://www.bilibili.com/video/BV1AZ4y1o7Ct/?spm_id_from=333.999.0.0运行代码:

cs 复制代码
  void QuickSort(int[] data, int left, int right)
  {
      //首先需要判断left与right的值
      if (left < right)
      {
          //进行分区,并返回一个基准值的索引值
          int pivotIdx = GetPivotIndex(data,left,right);
          QuickSort(data,left, pivotIdx - 1);
          QuickSort(data, pivotIdx + 1, right);
      }
  }

  private int GetPivotIndex(int[] data, int left, int right)
  {
      int pivot = data[left];

      while (left < right) 
      {
          if (left < right && data[right] >= pivot)
          {
              --right;
          }
          data[left] = data[right];
          if (left < right && data[left] <= pivot)
          {
              ++left;
          }
          data[right] = data[left];
      }
      //两边都交换完成,将pivot的值赋值给left对应的位置
      data[left] = pivot;
      return left;
  }

参考链接:

1.6 快速排序 | 菜鸟教程 (runoob.com)https://www.runoob.com/w3cnote/quick-sort-2.html

快速排序 | 菜鸟教程 (runoob.com)https://www.runoob.com/w3cnote/quick-sort.html

相关推荐
一切皆是因缘际会5 小时前
从概率拟合到内生心智:2026 下一代 AI 架构演进与落地实践
人工智能·深度学习·算法·架构
Java成神之路-5 小时前
【LeetCode 刷题笔记】34. 在排序数组中查找元素的第一个和最后一个位置 | 二分查找经典刷题题解
算法·leetcode
不忘不弃5 小时前
用BFS方法求解平分汽油问题
算法·宽度优先
AI科技星5 小时前
全域数学·72分册·射影原本 无穷维射影几何卷细化子目录【乖乖数学】
人工智能·线性代数·算法·机器学习·数学建模·数据挖掘·量子计算
风落无尘5 小时前
《智能重生:从垃圾堆到AI工程师》——第四章 变化的艺术
人工智能·线性代数·算法
JAVA面经实录9176 小时前
计算机基础(完整版·超详细可背诵)
java·linux·数据结构·算法
AC赳赳老秦6 小时前
知识产权辅助:用 OpenClaw 批量生成专利交底书 / 软著申请材料,自动校验格式与内容合规性
java·人工智能·python·算法·elasticsearch·deepseek·openclaw
WBluuue6 小时前
Codeforces 1093 Div2(ABCD1D2)
c++·算法
浅念-6 小时前
「一文吃透 BFS:从层序遍历到锯齿形、最大宽度、每层最大值」
数据结构·算法
汉克老师6 小时前
GESP5级C++考试语法知识(十三、贪心算法(一))
算法·贪心算法·海盗船·gesp5级·gesp五级·排队接水