406. Queue Reconstruction by Height

解法:
1: 按高度从高到低,高度相同时按k的值从小到大排序
2:按位置插入

class Solution {
public:
    vector<vector<int>> reconstructQueue(vector<vector<int>>& people) {
        sort(people.begin(), people.end(), [](vector<int>& p1, vector<int>& p2){
            return (p1[0] == p2[0])? p1[1] < p2[1] : p1[0] > p2[0];
        });
        // for(auto& p: people)
        //     cout<<"("<<p[0]<<","<<p[1]<<") ";
        // cout<<endl;
        vector<vector<int>> res;
        for(auto& p : people){
            res.insert(res.begin() + p[1], p);
        }
        return res;
    }
};
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。