鱼C论坛

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

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

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

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

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

x
// 快速排序算法

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

void qsort(int l, int r)
{
    int i = l, j = r, m = a[(l + r) / 2], temp;
    if (l >= r)
        return;
    do
    {
        while (a[i] < m)
            i++;
        while (a[j] > m)
            j--;
        if (i <= j)
        {
            temp = a[i];
            a[i] = a[j];
            a[j] = temp;
            i++;
            j--;
        }
    } while (i <= j);
    if (l < j)
        qsort(l, j);
    if (i < r)
        qsort(i, r);
}

int main()
{
    int n, i;
    cin >> n;
    for (i = 1; i <= n; i++)
        cin >> a[i];
    qsort(1, n);
    for (i = 1; i <= n; i++)
        cout << a[i] << " ";
    return 0;
}

不太理解代码意思

本帖被以下淘专辑推荐:

想知道小甲鱼最近在做啥?请访问 -> 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]快排,循环下去就可以

大概就是这么个样子
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-11-22 18:33

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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