鱼C论坛

 找回密码
 立即注册
查看: 2621|回复: 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
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-4-1 19:22

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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