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;
    }
};
相关推荐
征途菜哥5 分钟前
毛笔书体检测-hog+svm python opencv源码
算法·机器学习·支持向量机
大胆飞猪12 分钟前
dfs二叉树中的深搜(回溯、剪枝)--力扣129、814、230、257
算法·leetcode·深度优先·dfs
我不会JAVA!18 分钟前
C++ 实现A*算法
c++·算法
一叶祇秋26 分钟前
Leetcode - 双周赛135
算法·leetcode·职场和发展
小王努力学编程32 分钟前
贪心算法学习C++
开发语言·c++·学习·算法·leetcode·贪心算法
无限大642 分钟前
数据结构与算法入门 Day 0:程序世界的基石与密码
后端·算法·程序员
北京地铁1号线42 分钟前
菊厂20250416软件机考T2解答(200分)
python·算法
LAOLONG-C1 小时前
暂存一下等会写
算法
ChoSeitaku1 小时前
NO.94十六届蓝桥杯备战|图论基础-单源最短路|常规dijkstra|堆优化dijkstra|bellman-ford|spfa(C++)
c++·算法·图论
孤蓬&听雨1 小时前
Axure高保真AI算法训练平台
人工智能·算法·ai·产品经理·axure·原型设计