浅谈:从经典算法到实战优化的案例分析

有经验的的读者应该会有警觉性,这颗递归树在一些特殊数据情况下很有可能会由树 退化成链。从而使 O(nlogn) 的复杂度退化到 O(n^2)。

这样我们快速排序的效果就大打折扣了。

为了解决这个问题我们回到我们之前的处理方式,我们是直接选取问题序列的第一个元素的。因此很容易发现当数据是有序,或者重复数值很多的时候递归树就会往单个方向退化。因此我们可以使用 随机选点的方式,来使数据不会一边倒的集中。

例题

最后我们来一道排序数组的模板题作为练习。

复制代码
class Solution {
public:
    vector<int> sortArray(vector<int>& nums) {
        srand((unsigned)time(NULL));
        quickSort(nums, 0, nums.size() - 1);
        return nums;
    }
​
private:
    void quickSort(vector<int>& arr, const int first, const int last) {
        if (first >= last) {
            return;
        }
​
        // (优化)随机取一个数
        int randIdx = first + (rand() % (last - first + 1));
        swap(arr[randIdx], arr[first]);
​
        int left   = first;
        int right  = last;
        int border = arr[left];
        while (left < right) {
            while (left < right && border <= arr[right]) {
                right += -1;
            }
            arr[left] = arr[right];
            while (left < right && border >= arr[left]) {
                left += 1;
            }
            arr[right] = arr[left];
        }
        arr[left] = border;
​
        const int borderIdx = left;
        quickSort(arr, first, borderIdx - 1);
        quickSort(arr, borderIdx + 1, last);
    }
};

今天的文章分享到这里就结束了,希望认真阅读全文的小伙伴,都能有所收获哦!

相关推荐
sugar__salt7 小时前
从栈队列数据结构到JS原型面向对象全解
前端·javascript·数据结构
froyoisle9 小时前
CSP-J 历年复赛 T1 及解析(2019~2025)
数据结构·c++·算法·csp-j·csp·算法竞赛·信息学
喜欢打篮球的普通人10 小时前
LLVM 后端流程与关键数据结构:从 IR 到机器码的入门笔记
java·数据结构·笔记
Misnearch10 小时前
1、数组/字符串
java·数据结构·算法
008爬虫实战录10 小时前
【数据结构】 树、二叉树、完全二叉树,先序遍历、中序遍历、后序遍历
数据结构·算法
AllData公司负责人11 小时前
大模型赋能AllData数据中台,系列升级|通过联合智谱大模型与BiSheng开源项目,建设企业大模型应用开发平台,支持知识库向量检索!
大数据·数据结构·数据库·算法·大模型·向量数据库·智谱ai
梦想的颜色12 小时前
MySQL 数据存储结构与查询执行生命周期深度解析
运维·数据结构·数据库·mysql·线程·优化
Ameilide12 小时前
数据结构 算法解释,排序、查找
数据结构
真实的菜14 小时前
Redis 从入门到精通(二):深入数据结构 —— 从 RedisObject 到 SkipList 的源码级拆解
数据结构·redis·skiplist
小欣加油15 小时前
leetcode41 缺失的第一个正数
数据结构·c++·算法·leetcode