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;
    }
}
相关推荐
BAGAE5 小时前
星链卫星数据获取:从太空安全到实时通信的技术革命
网络·数据结构·数据库·算法·云计算·hbase
happymaker06265 小时前
LeetCodeHor100——438.找到字符串中所有的字母异位词
算法
西安邮电大学5 小时前
有关栈的经典算法题
java·后端·其他·算法·面试
h_a_o777oah6 小时前
【算法专项】扩展域并查集:原理详解及解决大部分种类并查集问题(洛谷P5937 P2024 C++代码)
数据结构·c++·算法·acm·并查集·扩展域·逻辑建模
兰令水6 小时前
leecodecode【单调栈】【2026.6.12打卡-java版本】
java·开发语言·算法
TMT星球6 小时前
魔法原子上交会首秀VLA K02大模型,完成具身智能从“执行”到“理解”的能力跃迁
人工智能·算法·机器学习
2301_764441336 小时前
番茄钟+AI:高效专注的秘密武器
人工智能·算法·数学建模·动态规划·交互
影寂ldy6 小时前
C# 泛型委托
java·算法·c#
星马梦缘6 小时前
算法设计与分析 作业三 纯答案
算法
吴阿福|一人公司6 小时前
深度解析 Python 类变量修改的命名空间隔离
java·服务器·数据结构