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;
    }
}
相关推荐
kukubuzai28 分钟前
搜索二叉数(c++)
算法
快手技术43 分钟前
效果 & 成本双突破!快手提出端到端生成式推荐系统 OneRec!
算法
HNU混子1 小时前
leetcode-3443. K次修改后的最大曼哈顿距离
算法·leetcode·动态规划
东方芷兰1 小时前
Leetcode 刷题记录 19 —— 动态规划
算法·leetcode·动态规划
奔跑吧邓邓子1 小时前
解锁决策树:数据挖掘的智慧引擎
人工智能·算法·决策树·机器学习·数据挖掘
蓝纹绿茶2 小时前
【本机已实现】使用Mac部署Triton服务,使用perf_analyzer、model_analyzer
人工智能·算法·macos·机器学习
范纹杉想快点毕业2 小时前
Qt实现文本编辑器光标高亮技术
java·开发语言·c++·算法·系统架构
C羊驼2 小时前
C语言:二分搜索函数
算法
胡乱编胡乱赢2 小时前
最小化联邦平均(FedAvg)的算法开销
算法·最小化联邦平均·联邦平均
The_cute_cat2 小时前
25.6.19学习总结
学习·算法