您的位置:首页 > 其它

LeetCode刷题笔记 406. 根据身高重建队列

2019-06-30 18:59 260 查看

题目描述

假设有打乱顺序的一群人站成一个队列。 每个人由一个整数对(h, k)表示,其中h是这个人的身高,k是排在这个人前面且身高大于或等于h的人数。 编写一个算法来重建这个队列。

示例:
输入:
[[7,0], [4,4], [7,1], [5,0], [6,1], [5,2]]
输出:
[[5,0], [7,0], [5,2], [6,1], [4,4], [7,1]]

总结

先由身高降序排序,k升序排序
然后用类似插入排序的方式得到结果集

Sample & Demo Code

class Solution {
public int[][] reconstructQueue(int[][] people) {
Arrays.sort(people, new Comparator<int[]>() {
@Override
public int compare(int[] o1, int[] o2) {
return o1[0] == o2[0] ? o1[1] - o2[1] : o2[0] - o1[0];
}
});

// for(int[] i : people)
//     System.out.println(i[0]+","+i[1]);

List<int[]> list = new ArrayList<>();
for(int[] i : people)
list.add(i[1], i);

return list.toArray(new int[list.size()][]);
// return list.toArray(people);
}
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: