欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 文旅 > 手游 > day44——根据身高重建队列(LeetCode-406)

day44——根据身高重建队列(LeetCode-406)

2025/4/16 23:39:53 来源:https://blog.csdn.net/the_dry/article/details/147219503  浏览:    关键词:day44——根据身高重建队列(LeetCode-406)

题目描述

假设有打乱顺序的一群人站成一个队列,数组 people 表示队列中一些人的属性(不一定按顺序)。每个 people[i] = [hi, ki] 表示第 i 个人的身高为 hi ,前面 正好 有 ki 个身高大于或等于 hi 的人。

请你重新构造并返回输入数组 people 所表示的队列。返回的队列应该格式化为数组 queue ,其中 queue[j] = [hj, kj] 是队列中第 j 个人的属性(queue[0] 是排在队列前面的人)。

    示例 1:

    输入:people = [[7,0],[4,4],[7,1],[5,0],[6,1],[5,2]]
    输出:[[5,0],[7,0],[5,2],[6,1],[4,4],[7,1]]
    解释:
    编号为 0 的人身高为 5 ,没有身高更高或者相同的人排在他前面。
    编号为 1 的人身高为 7 ,没有身高更高或者相同的人排在他前面。
    编号为 2 的人身高为 5 ,有 2 个身高更高或者相同的人排在他前面,即编号为 0 和 1 的人。
    编号为 3 的人身高为 6 ,有 1 个身高更高或者相同的人排在他前面,即编号为 1 的人。
    编号为 4 的人身高为 4 ,有 4 个身高更高或者相同的人排在他前面,即编号为 0、1、2、3 的人。
    编号为 5 的人身高为 7 ,有 1 个身高更高或者相同的人排在他前面,即编号为 1 的人。
    因此 [[5,0],[7,0],[5,2],[6,1],[4,4],[7,1]] 是重新构造后的队列。
    

    示例 2:

    输入:people = [[6,0],[5,0],[4,0],[3,2],[2,2],[1,4]]
    输出:[[4,0],[5,0],[2,2],[3,2],[1,4],[6,0]]
    

    提示:

    • 1 <= people.length <= 2000
    • 0 <= hi <= 106
    • 0 <= ki < people.length
    • 题目数据确保队列可以被重建

    解决方案:

    1、给出一个数前面有更大的数的个数,即可确定位置

    2、排序:降序排列,保证小数往前插入移动时,不会影响大数的值

    3、插入:插入位置,恰好等于小数的值

    函数源码:

    class Solution {
    public:vector<vector<int>> reconstructQueue(vector<vector<int>>& people) {vector<vector<int>>ans;sort(people.begin(),people.end(),[](vector<int>&a,vector<int>&b){if(a[0]==b[0])  return a[1]<b[1];return a[0]>b[0];});int pos;for(int i=0;i<people.size();i++){pos=people[i][1];ans.insert(ans.begin()+pos,people[i]);}return ans;}};

    版权声明:

    本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

    我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

    热搜词