说实话,这道题我没想出来,但是看解题报告题解比较让人觉得眼前一亮,这里记录下来

package y2019.Algorithm.greedy.medium;

import java.util.Arrays;
import java.util.LinkedList; /**
* @Auther: xiaof
* @Date: 2019/12/19 09:05
* @Description: 406. 根据身高重建队列
*
* 假设有打乱顺序的一群人站成一个队列。 每个人由一个整数对(h, k)表示,其中h是这个人的身高,k是排在这个人前面且身高大于或等于h的人数。 编写一个算法来重建这个队列。
* 注意:
* 总人数少于1100人。
*
* 示例
* 输入:
* [[7,0], [4,4], [7,1], [5,0], [6,1], [5,2]]
* 输出:
* [[5,0], [7,0], [5,2], [6,1], [4,4], [7,1]]
*
* 来源:力扣(LeetCode)
* 链接:https://leetcode-cn.com/problems/queue-reconstruction-by-height
* 著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
*
*/
public class ReconstructQueue { /**
* https://leetcode-cn.com/problems/queue-reconstruction-by-height/solution/406-gen-ju-shen-gao-zhong-jian-dui-lie-pai-xu-hou-/
* 执行用时 : 10 ms , 在所有 java 提交中击败了 76.85% 的用户
* 内存消耗 : 40 MB , 在所有 java 提交中击败了 99.37% 的用户
*/
public int[][] solution(int[][] people) {
//1.思路就是先按照升高排序,先按照升高排序,升高相同的按照第二个前面几个人进行排序
Arrays.sort(people, (v1, v2) -> v1[0] == v2[0] ? v1[1] - v2[1] : v2[0] - v1[0]);
//2.然后遍历数组,依次吧中的升高添加到数据中,然后把
//3.根据排好顺序的list,吧第二个参数作为下坐标add进入队列中
LinkedList<int[]> res = new LinkedList<>();
//因为已经加入linked的数据都是比当前遍历到的数据大的值,那么只要知道前面有几个比这个数大,直接插入即可
for (int[] i : people) {
res.add(i[1], i);
} return res.toArray(new int[res.size()][2]); } public static void main(String[] args) {
int[][] param1 = {{7,0}, {4,4}, {7,1}, {5,0}, {6,1}, {5,2}}; ReconstructQueue fuc = new ReconstructQueue();
System.out.println("需要添加对应的数据:");
int[][] res = fuc.solution(param1);
System.out.println("");
System.out.println(res); } }

2020年1月19日08:54:11 add  》》》》》》》》》》》》》》》》》

如果使用快排进行排序速度会更快

package y2019.Algorithm.greedy.medium;

import java.util.ArrayList;
import java.util.Arrays;
import java.util.LinkedList;
import java.util.List; /**
* @Auther: xiaof
* @Date: 2019/12/19 09:05
* @Description: 406. 根据身高重建队列 贪心算法
*
* 假设有打乱顺序的一群人站成一个队列。 每个人由一个整数对(h, k)表示,其中h是这个人的身高,k是排在这个人前面且身高大于或等于h的人数。 编写一个算法来重建这个队列。
* 注意:
* 总人数少于1100人。
*
* 示例
* 输入:
* [[7,0], [4,4], [7,1], [5,0], [6,1], [5,2]]
* 输出:
* [[5,0], [7,0], [5,2], [6,1], [4,4], [7,1]]
*
* 来源:力扣(LeetCode)
* 链接:https://leetcode-cn.com/problems/queue-reconstruction-by-height
* 著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
*
*/
public class ReconstructQueue { //使用快排 /**
* 执行用时 : 5 ms , 在所有 Java 提交中击败了 99.95% 的用户
* 内存消耗 : 43.1 MB , 在所有 Java 提交中击败了 93.71% 的用户
* @param people
* @return
*/
public int[][] solution2(int[][] people) {
//先进行快排
quikSort(people, 0, people.length);
//按照顺序插入list
// List<int[]> res = new ArrayList();
LinkedList<int[]> res = new LinkedList<>();
for (int[] i : people) {
res.add(i[1], i);
} return res.toArray(new int[res.size()][]);
} public void quikSort(int[][] people, int start, int end) {
if (start < end) {
int mid = midSite(people, start, end);
quikSort(people, start, mid);
quikSort(people, mid + 1, end);
}
} public int midSite(int[][] people, int start, int end) {
if (start >= end) {
return start;
} int midValue[] = people[start], l = start, r = end;
do {
do {
++l;
} while (l < end && compare(people[l], midValue)); do {
--r;
} while (start < r && compare(midValue, people[r])); //如果没有超出范围,交换位置
if (l < r) {
int[] tmp = people[l];
people[l] = people[r];
people[r] = tmp;
}
} while (l < r); //最后吧之前中间位置数据交换回来
people[start] = people[r];
people[r] = midValue; return r;
} //这里我们按照从大到小排序
public boolean compare(int[] p1, int[] p2) {
//比较,优先根据第二个数据比较,然后根据第一个数据比较大小
if (p1[0] != p2[0]) {
return p1[0] > p2[0];
} else {
//如果相等,第一个数据
return p1[1] < p2[1];
}
} public static void main(String[] args) {
int[][] param1 = {{7,0}, {4,4}, {7,1}, {5,0}, {6,1}, {5,2}}; ReconstructQueue fuc = new ReconstructQueue();
System.out.println("需要添加对应的数据:");
int[][] res = fuc.solution2(param1);
System.out.println("");
System.out.println(res); }
}

【LEETCODE】73、根据身高重建队列 第406题的更多相关文章

  1. LeetCode 406. 根据身高重建队列(Queue Reconstruction by Height) 46

    406. 根据身高重建队列 406. Queue Reconstruction by Height 题目描述 假设有打乱顺序的一群人站成一个队列.每个人由一个整数对 (h, k) 表示,其中 h 是这 ...

  2. Java实现 LeetCode 406 根据身高重建队列

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

  3. Leetcode 406.根据身高重建队列

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

  4. 【LeetCode】406-根据身高重建队列

    title: 406-根据身高重建队列 date: 2019-04-15 21:13:06 categories: LeetCode tags: Java容器 比较器 贪心思想 题目描述 假设有打乱顺 ...

  5. 406 Queue Reconstruction by Height 根据身高重建队列

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

  6. Leetcode:根据身高重建队列

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

  7. [Swift]LeetCode406. 根据身高重建队列 | 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 622:设计循环队列 Design Circular Queue

    LeetCode 622:设计循环队列 Design Circular Queue 首先来看看队列这种数据结构: 队列:先入先出的数据结构 在 FIFO 数据结构中,将首先处理添加到队列中的第一个元素 ...

  9. K:leetcode 5381.查询带键的排列 这题简单,但我还能优化。精益求精,才是算法的乐趣所在!

    前言: 本题来自leetcode第184场周赛的第二小题.以前参加过周赛,觉得很有趣.苦于最近一段时间比较忙就没坚持参加了(实际上是借口来着....),由于昨晚思考一些事情,导致睡不着,所以起得有点早 ...

随机推荐

  1. P4211 [LNOI2014]LCA LCT

    P4211 [LNOI2014]LCA 链接 loj luogu 思路 多次询问\(\sum\limits_{l \leq i \leq r}dep[LCA(i,z)]\) 可以转化成l到r上的点到根 ...

  2. HTML引入外部JS文件

    <!--引入外部文件的方式--> <script type="text/javascript" src="attack.js">< ...

  3. Linux文件系统只读Read-only file system的解决方法

    问题原因:系统没有正常关机,导致虚拟磁盘出现文件系统错误. 解决方法:使用fsck手动修复,具体操作如下: 重启系统后使用root进入单用户模式,运行 fsck.ext3 -y /dev/vda3 说 ...

  4. SpringBoot之文件上传体积过大问题(解决方案)

    错误信息如下(关键): org.apache.tomcat.util.http.fileupload.FileUploadBase$SizeLimitExceededException: the re ...

  5. 阿里P8架构师深度概述分布式架构

    简介 作为一名架构师,我们要专业,要能看懂代码,及时光着臂膀去机房,也能独挡一面!及时同事搞不定问题,或者撂挑子,你也能给老大一个坚定的眼神:不怕,有我在!还能在会议室上滔滔不绝,如若无人,让不懂技术 ...

  6. Mesa: GeoReplicated, Near RealTime, Scalable Data Warehousing

    Mesa的定义并没有反映出他的特点,因为分布式,副本,高可用,他都是依赖google的其他基础设施完成的 他最大的特点是,和传统数仓比,可以做到near real-time的返回聚合的查询结果 算入实 ...

  7. [转]import xxx from 和 import {xxx} from的区别

    原文地址:https://www.cnblogs.com/Abner5/p/7256043.html 1.vue import FunName from ‘../xxx’ 1.js export de ...

  8. Linux内核链表复用实现队列

    有了前面Linux内核复用实现栈的基础,使用相同的思想实现队列,也是非常简单的.普通单链表复用实现队列,总会在出队或入队的时候有一个O(n)复杂度的操作,大多数采用增加两个变量,一个head,一个ta ...

  9. spark 监控--WebUi、Metrics System(转载)

    转载自:https://www.cnblogs.com/barrenlake/p/4364644.html Spark 监控相关的部分有WebUi 及 Metrics System; WebUi用于展 ...

  10. Java12新特性 -- 增强G1,自动返回未用堆内存给操作系统

    Java 12 中增强了 G1 垃圾收集器关于混合收集集合的处理策略,这节主要介绍在 Java 12 中同时也对 G1垃圾回收器进行了改进,使其能够在空闲时自动将 Java 堆内存返还给操作系统,这也 ...