0
点赞
收藏
分享

微信扫一扫

本地化部署Chatglm和防踩坑攻略

徐一村 2024-07-28 阅读 22

归并排序也是分治的做法。

先确定中间点,再递归排序,再归并排序。一个指针一个指针的分别比大小。

每一层时间复杂度是O(n),整体上的时间复杂度是O(nlogn).

//代码实现
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);
}

举报

相关推荐

0 条评论