鱼C论坛

 找回密码
 立即注册
查看: 1909|回复: 1

[技术交流] C++ 快速排序算法

[复制链接]
发表于 2020-2-6 19:40:48 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
  1. // 快速排序算法

  2. #include <iostream>
  3. using namespace std;
  4. int a[1000] = {};

  5. void qsort(int l, int r)
  6. {
  7.     int i = l, j = r, m = a[(l + r) / 2], temp;
  8.     if (l >= r)
  9.         return;
  10.     do
  11.     {
  12.         while (a[i] < m)
  13.             i++;
  14.         while (a[j] > m)
  15.             j--;
  16.         if (i <= j)
  17.         {
  18.             temp = a[i];
  19.             a[i] = a[j];
  20.             a[j] = temp;
  21.             i++;
  22.             j--;
  23.         }
  24.     } while (i <= j);
  25.     if (l < j)
  26.         qsort(l, j);
  27.     if (i < r)
  28.         qsort(i, r);
  29. }

  30. int main()
  31. {
  32.     int n, i;
  33.     cin >> n;
  34.     for (i = 1; i <= n; i++)
  35.         cin >> a[i];
  36.     qsort(1, n);
  37.     for (i = 1; i <= n; i++)
  38.         cout << a[i] << " ";
  39.     return 0;
  40. }
复制代码


不太理解代码意思

本帖被以下淘专辑推荐:

小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2020-2-7 10:57:20 | 显示全部楼层
就是取其中一个元素,正着遍历到不比这个元素小的,反着遍历到不比这个元素大的,交换,直到两边遍历相遇,
每轮都用来确定取出的元素的最终位置,并保证其左侧均比这个元素小,右边均比这个元素大

随便写一个{3,7,2,6,1,5,4}记为A[1...7]
i=1,j=7
取出6,正着比较i确定i=2时A[i]比6大,j=7时A[j]比6小,交换成{3,4,2,6,1,5,7}
继续发现i=4,A[i]不小于6,j=6,A[j]不大于6,交换成{3,4,2,5,1,6,7}
继续发现i=6,A[i]不小于6,j=5,A[j]不大于6,i>=j,两边遍历相遇,不用交换,i=6为6的最终位置,
第一轮结束后6左边的都比6小,右边的都比6大

然后对A[1...5],A[7...7]快排,循环下去就可以

大概就是这么个样子
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-5-28 03:28

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表