1094. 拼车 --力扣 --JAVA

题目

车上最初有 capacity 个空座位。车 只能 向一个方向行驶(也就是说,不允许掉头或改变方向

给定整数 capacity 和一个数组 trips , trip[i] = [numPassengersi, fromi, toi] 表示第 i 次旅行有 numPassengersi 乘客,接他们和放他们的位置分别是 fromitoi 。这些位置是从汽车的初始位置向东的公里数。

当且仅当你可以在所有给定的行程中接送所有乘客时,返回 true,否则请返回 false

解题思路

  1. 车不允许掉头和改变方向,所以需要重最近位置开始接客;
  2. 根据上车位置对乘客进行排序;
  3. 遍历排序后的数组,通过map存储当前车上的乘客下车位置和人数;
  4. 通过list记录哪些位置有乘客下车,并在之后从map中删除该数据;
  5. 根据上下车乘客对座位进行加减,当座位小于0时则失败;

代码展示

java 复制代码
class Solution {
    public boolean carPooling(int[][] trips, int capacity) {
        //根据起始位置对数组进行排序
        Arrays.sort(trips, new Comparator<int[]>() {
            @Override
            public int compare(int[] o1, int[] o2) {
                return o1[1] - o2[1];
            }
        });
        //记录在哪个位置下去多少人
        Map<Integer,Integer> store = new HashMap<>();
        for (int i = 0; i < trips.length; i++){
            //存储已经下车的
            List<Integer> data = new ArrayList<>();
            for (Integer num : store.keySet()){
                if (trips[i][1] >= num){
                    //释放空座位,清除已下车的人
                    capacity += store.get(num);
                    data.add(num);
                }
            }
            for (Integer num : data){
                store.remove(num);
            }
            capacity -= trips[i][0];
            store.put(trips[i][2], store.getOrDefault(trips[i][2], 0) + trips[i][0]);
            if(capacity < 0){
                return false;
            }
        }
        return true;
    }
}
相关推荐
季明洵9 分钟前
二叉树的最小深度、完全二叉树的节点个数、平衡二叉树、路径总和、从中序与后序遍历序列构造二叉树
java·数据结构·算法·leetcode·二叉树
想进个大厂19 分钟前
代码随想录day63 64 65 66 图论08 09 10 11
c++·算法·图论
云泽80821 分钟前
蓝桥杯算法精讲:双指针算法四大经典例题深度剖析
算法·职场和发展·蓝桥杯
小龙报33 分钟前
【算法通关指南:算法基础篇】二分算法: 1.A-B 数对 2.烦恼的高考志愿
c语言·开发语言·数据结构·c++·vscode·算法·二分
yong999035 分钟前
NNDA、PDA、JPDA、IMM数据关联算法MATLAB实现
开发语言·算法·matlab
罗湖老棍子39 分钟前
加分二叉树(信息学奥赛一本通- P1580)(洛谷-P1040)
算法·区间dp·区间动态规划
再难也得平1 小时前
力扣54. 螺旋矩阵(Java解法)
算法·leetcode·矩阵
飞Link1 小时前
别再被异常数据骗了:深度解析 TSTD 异常检测中的重构模型(AutoEncoder 实战)
人工智能·算法·重构·回归
小曹要微笑1 小时前
C#中的各种数据类型
算法·c#·数据类型·c#数据类型