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

二维数组多次排序 或 嵌套list多次排序

可以排序int[ ][ ]的顺序,也可以排序List<List<Integer>> 顺序

为便于理解,以力扣原题为例:1333.餐厅过滤器

原题中给了一个双重数组,并要求返回一个List<Integer>。

方法1
会用流的,通常用于会反应把双重数组转成List<List<Integer>>去处理这个双重数组,于是解题思路如下:

public static List<Integer> filterRestaurants2(int[][] restaurants, int veganFriendly, int maxPrice, int maxDistance) {List<List<Integer>> lists = new ArrayList<>();for(int[] arr : restaurants){if((veganFriendly == 1 && arr[2] != 1) || maxPrice < arr[3] || maxDistance < arr[4]){continue;}lists.add(Arrays.stream(arr).boxed().collect(Collectors.toList()));}if (lists.size() == 0) {return new ArrayList<>();}lists.sort((a,b) ->{int rating = b.get(1).compareTo(a.get(1));if (rating != 0) {return rating;}return b.get(0).compareTo(a.get(0));});return lists.stream().map(o->o.get(0)).collect(Collectors.toList());
}

可是该方式耗空间较大,于是又会想,能不能从直接用数组的方式,不另外构造新对象。

方法2:

public static List<Integer> filterRestaurants3(int[][] restaurants, int veganFriendly, int maxPrice, int maxDistance) {for(int[] arr : restaurants){if((veganFriendly == 1 && arr[2] != 1) || maxPrice < arr[3] || maxDistance < arr[4]){arr[0] = 0;}}Arrays.sort(restaurants, (o1, o2) -> {int compare = Integer.compare(o2[1], o1[1]);if (compare != 0){return compare;}return Integer.compare(o2[0], o1[0]);});return Arrays.stream(restaurants).map((int[] o)->o[0]).filter(o->o!=0).collect(Collectors.toList());
}

但是提交的结果然后是耗时耗空间。
既然数组能用流处理,那是不是可以全部用流的形式过滤和排序呢
方法3:

public static List<Integer> filterRestaurants(int[][] restaurants, int veganFriendly, int maxPrice, int maxDistance) {return Arrays.stream(restaurants).filter(r -> (veganFriendly != 1 || r[2] == 1) && r[3] <= maxPrice && r[4] <= maxDistance).sorted((a1, a2) -> a1[1] == a2[1] ? a2[0] - a1[0] : a2[1] - a1[1]).map(a -> a[0]).collect(Collectors.toList());
}
http://www.lryc.cn/news/187458.html

相关文章:

  • Flutter - 波浪动画和lottie动画的使用
  • 忘记压缩包密码?解决方法一键找回,省时又便捷!
  • “UTONMOS”掀起元宇宙游戏热潮,全球发展前景广阔
  • 用idea工具scala 和 Java开发 spark案例:WordCount
  • 【git merge/rebase】详解合并代码、解决冲突
  • nrm,npm源的管理工具
  • HarmonyOS/OpenHarmony原生应用-ArkTS万能卡片组件Stack
  • 腾讯云2核4G服务器一年和三年价格性能测评
  • 集线器、交换机、路由器是如何转发包的
  • 交通物流模型 | MDRGCN:用于多模式交通客流预测的深度学习模型
  • 保研经历分享(一)
  • 【手写数字识别】数据挖掘实验二
  • 什么是云计算?云计算简介
  • Vue路由进阶--VueRouter声明式导航
  • Oracle 云服务即将支持 PostgreSQL!
  • 数字孪生项目:突破技术难关,引领未来发展
  • MySQL 如何使用离线模式维护服务器
  • 期权开户流程合集——期权开户的操作步骤
  • mysql改造oracle,以及项目改造
  • 利用互斥锁实现多个线程写一个文件
  • 【m98】视频缓存PacketBuffer 1 : SeqNumUnwrapper int64映射、ForwardDiff
  • day58:ARMday5,GPIO流水灯实验
  • Linux shell编程学习笔记9:字符串运算 和 if语句
  • 【分享】xpath的属性表达式
  • Oracle Dataguard跨版本数据迁移(11.2.0.4~19.13.0.0)
  • 零基础Linux_14(基础IO_文件)缓冲区+文件系统inode等
  • Vue中的router路由的介绍(快速入门)
  • ESP-07S进行TCP 通信测试
  • 如何找到新媒体矩阵中存在的问题?
  • MongoDB-基本常用命令