作者: 负雪明烛
id: fuxuemingzhu
个人博客: http://fuxuemingzhu.cn/


题目地址:https://leetcode.com/problems/queue-reconstruction-by-height/#/description

题目描述

Suppose you have a random list of people standing in a queue. Each person is described by a pair of integers (h, k), where h is the height of the person and k is the number of people in front of this person who have a height greater than or equal to h. Write an algorithm to reconstruct the queue.

Note:
The number of people is less than 1,100.

Example:

  1. Input:
  2. [[7,0], [4,4], [7,1], [5,0], [6,1], [5,2]]
  3. Output:
  4. [[5,0], [7,0], [5,2], [6,1], [4,4], [7,1]]

题目大意

给出了一个数组,数组的每个元素表示一个人的身高以及在一个队伍前面不比他矮的人的个数。现在要重新排列,使得数组是满足条件的。

解题方法

这个题怎么想出来的呢?是因为我们考虑如果先把个子高的排好序,那么在任何位置插入数据都不会对已经排好序的数组造成影响。而,与此同时,我们已经知道了个子高的排序,那么当新的数据到的时候,我们要确定它的位置也很简单,因为现在的所有数据都比他高,所以只要根据他的第二个数字确定他的位置即可。

先对已有的数组进行排序。按照高度降序排列,如果高度一样,按照k的值升序排列。这样比如一开始[7,0] [7,1] [7,2]就会排好,然后比如说后面有一个[6,1], 说明只有一个大于或等于它,又因为比6大的已经全部取出。所以把它放在位置1,这样就变成[7,0] [6,1] [7,1] [7,2].然后比如又有一个[5,0].就放在位置0,以此类推。

即对于案列。首先排序成:

  1. [[7,0],[7,1],[6,1],[5,0],[5,2],[4,4]]

然后对于第二个数字进行插入对应位置:

  1. [[5,0], [7,0], [5,2], [6,1], [4,4], [7,1]]

Python代码如下:

  1. class Solution(object):
  2. def reconstructQueue(self, people):
  3. """
  4. :type people: List[List[int]]
  5. :rtype: List[List[int]]
  6. """
  7. people.sort(key = lambda x : (-x[0], x[1]))
  8. res = []
  9. for p in people:
  10. res.insert(p[1], p)
  11. return res

C++代码如下,需要注意自定义sort()函数的比较方法。

  1. class Solution {
  2. public:
  3. vector<pair<int, int>> reconstructQueue(vector<pair<int, int>>& people) {
  4. sort(people.begin(), people.end(), [](const pair<int, int> a, const pair<int, int> b) {
  5. return (a.first > b.first) || (a.first == b.first && a.second < b.second);
  6. });
  7. vector<pair<int, int>> res;
  8. for (auto p : people) {
  9. res.insert(res.begin() + p.second, p);
  10. }
  11. return res;
  12. }
  13. };

Java代码如下,之前写的,有点冗长了。

  1. public class Solution {
  2. public int[][] reconstructQueue(int[][] people) {
  3. if (people == null || people.length == 0) {
  4. return people;
  5. }
  6. Arrays.sort(people, new Comparator<int[]>() {
  7. @Override
  8. public int compare(int[] p1, int[] p2) {
  9. return p1[0] == p2[0] ? p1[1] - p2[1] : p2[0] - p1[0];
  10. }
  11. });
  12. List<int[]> temp = new ArrayList<int[]>();
  13. for (int[] aPeople : people) {
  14. if (people.length == aPeople[1]) {
  15. temp.add(aPeople);
  16. } else {
  17. temp.add(aPeople[1], aPeople);
  18. }
  19. }
  20. int ans[][] = new int[people.length][2];
  21. for (int i = 0; i < temp.size(); i++) {
  22. ans[i] = temp.get(i);
  23. }
  24. return ans;
  25. }
  26. }

日期

2017 年 3 月 30 日
2018 年 12 月 6 日 —— 周四啦!

【LeetCode】406. Queue Reconstruction by Height 解题报告(Python & C++ & Java)的更多相关文章

  1. sort学习 - LeetCode #406 Queue Reconstruction by Height

    用python实现多级排序,可以像C语言那样写个my_cmp,然后在sort的时候赋给参数cmp即可 但实际上,python处理cmp 是很慢的,因为每次比较都会调用my_cmp:而使用key和rev ...

  2. LN : leetcode 406 Queue Reconstruction by Height

    lc 406 Queue Reconstruction by Height 406 Queue Reconstruction by Height Suppose you have a random l ...

  3. [LeetCode] 406. Queue Reconstruction by Height 根据高度重建队列

    Suppose you have a random list of people standing in a queue. Each person is described by a pair of ...

  4. [leetcode] 406. Queue Reconstruction by Height

    https://leetcode.com/contest/6/problems/queue-reconstruction-by-height/ 分析:每个表示成(a,b)的形式,其实找第一个,就是b为 ...

  5. [leetcode] 406. Queue Reconstruction by Height (medium)

    原题 思路: 一开始完全没有思路..看了别人的思路才解出来. 先按照他们的高度从高到低(因为我后面用的从前往后遍历插入,当然也可以从低到高)排序,如果高度一样,那么按照k值从小到大排序. 排完序后我们 ...

  6. 【LeetCode】206. Reverse Linked List 解题报告(Python&C++&java)

    作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 迭代 递归 日期 [LeetCode] 题目地址:h ...

  7. LC 406. Queue Reconstruction by Height

    Suppose you have a random list of people standing in a queue. Each person is described by a pair of ...

  8. LeetCode_406. Queue Reconstruction by Height解题思路

    题目如下: Suppose you have a random list of people standing in a queue. Each person is described by a pa ...

  9. 406. Queue Reconstruction by Height

    一开始backtrack,设计了很多剪枝情况,还是TLE了 ..后来用PQ做的. 其实上面DFS做到一半的时候意识到应该用PQ做,但是不确定会不会TLE,就继续了,然后果然TLE了.. PQ的做法和剪 ...

随机推荐

  1. Linux服务器I/O性能分析-2

    一.如何正确分析IO性能 1.1 BLKTRACE分析IO性能 之前的文章已经说明,要是系统发生I/O性能问题,我们常用的命令是无法精确定位问题(内核I/O调度器消耗的时间和硬件消耗的时间,这个不能作 ...

  2. Linux关机/重启/用户切换/注销

    目录 1. 关机/重启命令 2. 用户切换/注销 2.1 基本说明 2.2 切换用户 2.3 注销用户 1. 关机/重启命令 # shutdown命令 shutdown -h now # 立即关机 s ...

  3. Linux—linux 查看一个文件有多少M

    ls -l --block-size=M   #就把目录下的所有文件按M单位呈现

  4. Bebug与Release版本

    如果调试过程无调试信息,检查编译选项是否切换到了release下 比如Cfree5等编译器 ms为了方便调试才诞生了DEBUG版. 这也导致了MFC有两个功能一至但版本不同的类库,一个为DEBUG版, ...

  5. do{...}while(0)的用法

    零.导引第一次见到 do{...}while(0)是在学习libevent的时候,看到里面有很多类似#define TT_URI(want) do { \ char *ret = evhttp_uri ...

  6. 学习Java的第十八天

    一.今日收获 1.java完全学习手册第三章算法的3.1比较值 2.看哔哩哔哩上的教学视频 二.今日问题 1.在第一个最大值程序运行时经常报错. 2.哔哩哔哩教学视频的一些术语不太理解,还需要了解 三 ...

  7. 转 android开发笔记之handler+Runnable的一个巧妙应用

    本文链接:https://blog.csdn.net/hfreeman2008/article/details/12118817 版权 1. 一个有趣Demo: (1)定义一个handler变量 pr ...

  8. weak和拷贝

    weak/拷贝 1. weak 只要没有strong指针指向对象,该对象就会被销毁 2. 拷贝 NSString和block用copy copy语法的作用 产生一个副本 修改了副本(源对象)并不会影响 ...

  9. 一行配置搞定 Spring Boot项目的 log4j2 核弹漏洞!

    相信昨天,很多小伙伴都因为Log4j2的史诗级漏洞忙翻了吧? 看到群里还有小伙伴说公司里还特别建了800+人的群在处理... 好在很快就有了缓解措施和解决方案.同时,log4j2官方也是速度影响发布了 ...

  10. Redis主从 部署和配置

    目录 一.主从简介 主从介绍 主从原理 二.主从部署 环境介绍 主从配置 临时主从 三.主从测试 一.主从简介 主从介绍 Redis都是主节点.每个从节点只能有一个主节点,而主节点可以同时具有多个从节 ...