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

根据身高重建队列【贪心算法】

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

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

class Solution {public int[][] reconstructQueue(int[][] people) {//先进行按照身高降序排列,身高相等则把k小的排在前面Arrays.sort(people, (a, b) -> {if (a[0] == b[0]) return a[1] - b[1];//身高相等,则按照k升序的方式进行排列;注意a - b 代表正序,从小到大return b[0] - a[0];//否则,按照身高h的降序进行排列});//需要将重构后的people重新进行定位,需要按照k值确认其需要插入的位置//重新构造的结果有顺序,应该用链表进行存储,这样插值的过程时间复杂度较低LinkedList<int[]> que = new LinkedList<>();//泛型的确定?为什么用int[],代表表里的是外层元素,而内部不用关心,拿来用即可//接下来遍历按照身高进行排序后的结果for (int[] p : people) {que.add(p[1], p);//插入到链表的对应的索引}return que.toArray(new int[people.length] []);//将链表转化为数组}
}
http://www.lryc.cn/news/147222.html

相关文章:

  • 基于Java+SpringBoot+Mybaties-plus+Vue+ElementUI 高校汉服租赁网站的 设计与实现
  • SQL-DQL
  • 手写深拷贝方法
  • 格子游戏——并查集
  • 2023最新Python重点知识万字汇总
  • 【STM32】学习笔记(TIM定时器)-江科大
  • Parallel Context Windows for Large Language Models
  • 怎么消除人声保留背景音乐?试试这几种简单方法
  • 积分游戏小程序模板源码
  • IDEA启动两个Tomcat服务的方式 使用nginx进行反向代理 JMeter测试分布式情况下synchronized锁失效
  • Shell 脚本入门
  • 管理类联考——逻辑——形式逻辑——汇总篇——知识点突破——性质模态
  • 无涯教程-Android - ToggleButton函数
  • unity VS无法进行断点调试
  • Pandas由入门到精通-组合与合并数据
  • Unexpected mutation of “xxxx“ prop
  • 七、基础篇总结
  • 前端面试基础面试题——2
  • docker 搭建rknn转换环境
  • 机器学习:争取被遗忘的权利
  • MATLAB实现AHP层次分析法——以情人节选取礼物为例
  • flutter使用Chanel与原生通信
  • Kubernetes技术--k8s核心技术Helm
  • C/C++学习——单例模式(懒汉模式与饿汉模式)
  • 企业微信网页开发本地调试方式
  • Prompt GPT推荐社区
  • 小程序隐私保护授权处理方式之弹窗组件
  • Java 复习笔记 - 方法篇
  • 大数据到底是好是坏?_光点科技
  • C++ while 循环