算法:快排(三指针算法)

1.三指针算法

在力扣题库中,题型中添加了超大量的重复数据;根本无法使用sort快排,一使用就超时;

三指针快排,是在双指针快排下,提出的优化方案,

无重复数据推荐使用双指针快排;

大量重复数据推荐使用三指针快排;

如果在数据结构章节,已经学会了快排的精髓;三指针代码一看就会;

2.题型

力扣:75、912、215、159;

3.模版代码如下

简单叙述如下:找到nums中的一个数key,将小于key的放在左边,大于key的放在右边;这样key的相对位置就确定了;(如果不理解请看我的一篇文章:数据结构:插入排序****)再把小于key的,和大于key的,那两个区域如此排好序;

cpp 复制代码
vector<int> sortArray(vector<int>& nums) {
        srand(time(NULL)); // 种下随机数种子
        quicksort(nums, 0, nums.size() - 1);
        return nums;
    }
    void quicksort(vector<int>& nums, int l, int r) {
        if (l >= r) return;
        // 数据分三块
        int key = getRandom(nums, l, r);
        int i = l, left = l - 1;
        int right = r + 1;
        while (i < right) {
            if (nums[i] < key) {
                left++;
                swap(nums[i], nums[left]);
                i++;
            } else if (nums[i] >key) {
                right--;
                swap(nums[i], nums[right]);
            } else i++;
        }
        //[1,left][left,right-1][right,r]
        quicksort(nums,l,left);
        quicksort(nums,right,r);
    }
    int getRandom(vector<int>& nums, int left, int right) {
        int r = rand();
        return nums[r % (right - left + 1) + left];
    }

4.提示

4.1千万不要相信,数据的绝对随机性;因为数据都是人写出来的,都是伪随机的,或人为排列的;所以只能再次通过种随机数种子伪随机,达到空间和时间复杂度的最小化;

相关推荐
誓约酱6 分钟前
排序算法 -计数排序
数据结构·c++·算法·排序算法
Fms_Sa26 分钟前
分别写出在散列表中插入和删除关键字为K的一个记录的算法,设散列函数为H,解决冲突的方法为链地址法。
c语言·数据结构·算法·哈希算法·散列表
Trouvaille ~28 分钟前
【优选算法篇】化繁为简,见素抱朴:从乱象中重构秩序的艺术
c++·算法·面试·蓝桥杯·排序算法·快速排序·分治
繁星璀璨G1 小时前
C++11标准模板(STL)- 常用数学函数 - 宏常量 - 求值得到float类型的安静NaN(NAN)
开发语言·c++·算法·stl·常用数学函数·nan
红队it1 小时前
【计算机毕设】无查重 基于python豆瓣电影评论舆情数据可视化系统(完整系统源码+数据库+开发笔记+详细部署教程)✅
数据库·笔记·python·算法·机器学习·信息可视化·数据分析
白鹭float.1 小时前
【算法速刷(10/100)】LeetCode —— 23. 合并 K 个升序链表
算法·leetcode
我焦虑的编程日记1 小时前
【蓝桥杯算法】Java的基础API
java·算法·排序算法
zhuzhuxia⌓‿⌓1 小时前
求矩阵中最小元素及其位置
c语言·算法
Horacek2 小时前
《C++ 实现生成多个弹窗程序》
java·开发语言·c++·学习·算法
zero_one_Machel2 小时前
leetcodeQ76最小覆盖子串
java·开发语言·算法