1094. 拼车 --力扣 --JAVA

简介: 车上最初有 capacity 个空座位。车 只能 向一个方向行驶(也就是说,不允许掉头或改变方向)给定整数 capacity 和一个数组 trips ,  trip[i] = [numPassengersi, fromi, toi] 表示第 i 次旅行有 numPassengersi 乘客,接他们和放他们的位置分别是 fromi 和 toi 。这些位置是从汽车的初始位置向东的公里数。当且仅当你可以在所有给定的行程中接送所有乘客时,返回 true,否则请返回 false。

 题目

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

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

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

解题思路

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

    代码展示

    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;
        }
    }

    image.gif


    目录
    相关文章
    |
    4月前
    |
    算法 Java
    LeetCode(一)Java
    LeetCode(一)Java
    |
    6月前
    |
    存储 算法 Java
    LeetCode经典算法题:打家劫舍java详解
    LeetCode经典算法题:打家劫舍java详解
    92 2
    |
    6月前
    |
    人工智能 算法 Java
    LeetCode经典算法题:井字游戏+优势洗牌+Dota2参议院java解法
    LeetCode经典算法题:井字游戏+优势洗牌+Dota2参议院java解法
    69 1
    |
    6月前
    |
    存储 算法 Java
    LeetCode经典算法题:预测赢家+香槟塔java解法
    LeetCode经典算法题:预测赢家+香槟塔java解法
    94 1
    |
    6月前
    |
    算法 Java
    LeetCode经典算法题:矩阵中省份数量经典题目+三角形最大周长java多种解法详解
    LeetCode经典算法题:矩阵中省份数量经典题目+三角形最大周长java多种解法详解
    80 6
    |
    6月前
    |
    存储 算法 Java
    LeetCode经典算法题:二叉树遍历(递归遍历+迭代遍历+层序遍历)以及线索二叉树java详解
    LeetCode经典算法题:二叉树遍历(递归遍历+迭代遍历+层序遍历)以及线索二叉树java详解
    97 0
    |
    6月前
    |
    算法 Java
    LeetCode初级算法题:环形链表+排列硬币+合并两个有序数组java解法
    LeetCode初级算法题:环形链表+排列硬币+合并两个有序数组java解法
    74 0
    |
    6月前
    |
    存储 算法 Java
    LeetCode初级算法题:两数之和+斐波拉契数列多种java解法
    LeetCode初级算法题:两数之和+斐波拉契数列多种java解法
    65 0
    |
    6月前
    |
    算法 Java 索引
    LeetCode初级算法题:寻找数组的中心索引+x的平方根+三个数的最大乘积+Leetcode 149:直线上最多的点数 Java详解
    LeetCode初级算法题:寻找数组的中心索引+x的平方根+三个数的最大乘积+Leetcode 149:直线上最多的点数 Java详解
    52 0
    |
    6月前
    |
    存储 算法 Java
    LeetCode初级算法题:反转链表+统计N以内的素数+删除排序数组中的重复项Java详解
    LeetCode初级算法题:反转链表+统计N以内的素数+删除排序数组中的重复项Java详解
    55 0