quick sort的实现

举报
irrational 发表于 2022/01/19 00:17:01 2022/01/19
【摘要】 quick sort其实很简单,就是找到一个指标x,让左边的元素都小于他,右边的元素都大于他,仅此而已。然后就是看递归去大显身手了。 #include <iostream> using namespace std; const int N = 100010; int q[N]; void quick_sort(int ...

quick sort其实很简单,就是找到一个指标x,让左边的元素都小于他,右边的元素都大于他,仅此而已。然后就是看递归去大显身手了。


      #include <iostream>
      using namespace std;
      const int N = 100010;
      int q[N];
      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);
      }
      int main()
      {
         int n;
          scanf("%d", &n);
         for (int i = 0; i < n; i ++ ) scanf("%d", &q[i]);
          quick_sort(q, 0, n - 1);
         for (int i = 0; i < n; i ++ ) printf("%d ", q[i]);
         return 0;
      }
  
 

文章来源: blog.csdn.net,作者:irrationality,版权归原作者所有,如需转载,请联系作者。

原文链接:blog.csdn.net/weixin_54227557/article/details/120591997

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。