LEEDCODE 1122数组的相对排序

cpp 复制代码
class Solution {
public:
    vector<int> relativeSortArray(vector<int>& arr1, vector<int>& arr2) {
        int cur = 0;
        for(int i = 0; i < arr2.size(); i++)
        {
            // arr2[i]
            for(int j = cur; j < arr1.size(); j++)
            {
                if(arr1[j] == arr2[i])
                {
                    swap(arr1[cur],arr1[j]);
                    cur += 1;
                }
            }
        }
        if(cur < arr1.size())
        {
            int left = cur;
            int right = arr1.size() - 1;
            quicksort(arr1, left, right);
        }
        return arr1;

    }
    void quicksort(vector<int>& arr1, int left, int right)
    {
        if(left>=right)
            return;
        int start = left;
        int end = right;
        int pivot = arr1[left];
        while(left < right)
        {
            while(arr1[right]>=pivot && left<right)
            {
                right -= 1;
            }
            while(arr1[left]<=pivot && left<right)
            {
                left += 1;
            }
            swap(arr1[left],arr1[right]);
        }
        swap(arr1[left],arr1[start]);
        quicksort(arr1, start, left - 1);
        quicksort(arr1, left + 1, end);
    }
    void swap(int& a, int& b)
    {
        int tmp = a;
        a = b;
        b = tmp;
    }
};
相关推荐
STY_fish_201210 分钟前
P11855 [CSP-J2022 山东] 部署
算法·图论·差分
myw07120510 分钟前
湘大头歌程-Ride to Office练习笔记
c语言·数据结构·笔记·算法
H_BB12 分钟前
算法详解:滑动窗口机制
数据结构·c++·算法·滑动窗口
Zero-Talent14 分钟前
“栈” 算法
算法
橘子编程14 分钟前
经典排序算法全解析
java·算法·排序算法
waeng_luo14 分钟前
【鸿蒙开发实战】智能数据洞察服务:待回礼分析与关系维护建议算法
算法·ai编程·鸿蒙
风筝在晴天搁浅15 分钟前
代码随想录 279.完全平方数
算法
不穿格子的程序员18 分钟前
从零开始刷算法——字串与区间类经典题:前缀和 + 单调队列双杀
算法·前缀和·哈希表·双向队列·单调队列
坚持就完事了19 分钟前
十大排序算法
数据结构·算法·排序算法
im_AMBER30 分钟前
Leetcode 63 定长子串中元音的最大数目
c++·笔记·学习·算法·leetcode