leetcode_刷题总结(c++)_分治算法(减治算法)_快速排序

主要参考:
第 6 节 三路快排

分治算法

分而治之

条件:
(1)原问题可以分解成若干个规模比较小的相同子问题。
(2)子问题相互独立。
(3)子问题的解可以合并为原问题的解。

快速排序

划分函数 partition

写法一:

    int partition(vector<int>& arr, int low, int high){
    	int i=low,j=high;
        int base=arr[low];//选取第一个元素作为基准
        while(i<j){
            while(i<j && arr[j]> base ){//high从右往左扫描 寻找小于base的值
                j--;
            }
            if(i<j){//交换
				swap(arr[i], arr[j]);
                i++;
            }
            while(i<j && arr[i]<=base){//high从左往右扫描 寻找大于base的值
            	i++;
            }    
            if(i<j){
            	swap(arr[i], arr[j]);
            	j--;
            }    
        }
        return i;
    }

写法二:

	int partition(vector<int>& arr, int low, int high) {
        if(low > high)
            return low;
        int i=low;
        int j=high;
        int base=arr[low];
        while(i<j){
            while(i<j && arr[j]>=base)
                j--;
            while(i<j && arr[i]<=base)
                i++;
            if(i<j){
                int t = arr[i];
                arr[i] = arr[j];
                arr[j] = t;
                //swap(arr[i],arr[j]);
            }
        }
        arr[low]=arr[i];
        arr[i]=base;
        //swap(arr[low],arr[i]);
        return i;
    }

在这里插入图片描述

快排递归算法 quick_sort

    void quick_sort(vector<int>& arr, int start, int end){
        int pos;
        if (start<end){
            pos = partition(arr, start, end);
            quick_sort(arr,start,pos-1);
            quick_sort(arr,pos+1,end);
        }
        return;
    }

三划分快排

详细可看视频:第 6 节 三路快排

	void Quick_Sort(vector<int> &nums, int left, int right){
        if (left >= right) 
            return;

        int lt = left+1;
        int gt = right;
        int i = left+1;     
        swap(nums[left], nums[rand() % (right - left + 1) + left]);
        int temp = nums[left];
        while(i <= gt){
            if(nums[i] < temp){
                swap(nums[i], nums[lt]);
                i++;
                lt++;
            }
            else if(nums[i] == temp){
                i++;
            }
            else if(nums[i] > temp){
                swap(nums[i], nums[gt]);
                gt--;
            }
        }
        swap(nums[left], nums[lt-1]);
        Quick_Sort(nums, left, lt-1);
        Quick_Sort(nums, gt+1, right);
        
    }

在这里插入图片描述

leetcode部分题目

75. 颜色分类

75. 颜色分类
在这里插入图片描述
快排:

class Solution {
public:
    int partition(vector<int>& arr, int low, int high){
    	int i=low,j=high;
        int base=arr[low];//选取第一个元素作为基准
        while(i<j){
            while(i <j && arr[j]> base ){//high从右往左扫描 寻找小于base的值
                j--;
            }
            if(i<j){//交换
				swap(arr[i], arr[j]);
                i++;
            }
            while(i<j && arr[i]<=base){//high从左往右扫描 寻找大于base的值
            	i++;
            }    
            if(i<j){
            	swap(arr[i], arr[j]);
            	j--;
            }    
        }
        return i;
    }
    void quick_sort(vector<int>& arr, int start, int end){
        int pos;
        if (start<end){
            pos = partition(arr, start, end);
            quick_sort(arr,start,pos-1);
            quick_sort(arr,pos+1,end);
        }
        return;
    }
    void sortColors(vector<int>& nums) {
        //快排 以1为基准 扫描一次可以得到最终结果
        quick_sort(nums,0,nums.size()-1);
    }
};
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值