当前位置: 首页 > news >正文

力扣406 根据身高重建队列 java实现

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
  • 题目数据确保队列可以被重建

按照身高h来排序,从大到小排(身高相同的话则k小的站前面),让高个子在前面。前面的节点一定都比本节点高,那么只需要按照k为下标重新插入队列就可以了。

具体代码如下:

public static void main(String[] args) { // 测试用 int[][] nums = {}; int[][] res = reconstructQueue(nums); for (int[] ints : res) { System.out.println(Arrays.toString(ints)); } } public static int[][] reconstructQueue(int[][] people) { Arrays.sort(people,(a,b) ->{ if (a[0] == b[0]){ return a[1] - b[1]; } return b[0] - a[0]; }); List<int[]> list = new ArrayList<>(); for (int[] ints : people) { list.add(ints[1], ints); } return list.toArray(new int[people.length][]); }

以上为记录分享用,代码较差请见谅

http://www.gsyq.cn/news/188867.html

相关文章:

  • 西门子时间计数器
  • 一个 Bug,把 MIT 工程师从谷歌逼醒
  • AI自动画界面?Google这个开源神器让前端工程师失业了
  • 数据驱动未来:大数据价值实现的创新方法
  • 低功耗蓝牙主机与从机四种数据交流方式
  • AI-Rime V3——指尖AI
  • AI Agent的多语言支持:跨语言理解与生成
  • 函数式编程:Lambda 表达式:Compose 的核心。比如 { onClick() },请直接给出一些练习事例出来
  • Java CountDownLatch 代码示例:协调多个线程的执行顺序(比赛起跑)
  • Segmentation Fault 调试指南:gdb + ASan + Valgrind 全流程实战
  • 电气设备的发热量计算
  • 不止是整理
  • 北京陪诊机构推荐守嘉陪诊:全链条护航让首都就医更从容 - 品牌排行榜单
  • Java+React全栈开发面试宝典(完整60题)
  • 云服务器成本管控:从粗放投入到精细运营
  • 云服务器架构演进:从虚拟化到容器化与无服务器的跨越
  • 云服务器架构演进:从虚拟化到容器化与无服务器的跨越
  • 墨香飘洋:当外国友人执起中国毛笔
  • 科研牛马千万不要错过!手把手教你用AI精准匹配真实参考文献,仅需一个专业应用+两个提示词指令
  • 云服务器运维实战:从环境搭建到安全加固全流程​
  • CCF-GESP计算机学会等级考试2025年12月三级C++T2 小杨的智慧购物
  • 行车记录仪乱码大揭秘:数据恢复不再是难题!
  • CCF-GESP计算机学会等级考试2025年12月四级C++T1 建造
  • 云服务器 vs 传统服务器:核心区别与选型指南​
  • java基于Springboot卖家乐二手电子产品回收系统-vue
  • CCF-GESP计算机学会等级考试2025年12月一级C++T2 手机电量显示
  • 断网服务器如何防“物理入侵”?用SLA 操作系统双因素认证实现离线双因子认证
  • 2026年京东e卡回收技巧,高效变现的五大策略 - 京顺回收
  • 随机森林算法实现与测试 -
  • LangChain Tools解析:让Agent拥有超能力