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

1094. 拼车 --力扣 --JAVA

题目

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

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

当且仅当你可以在所有给定的行程中接送所有乘客时,返回 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;
    }
}


http://www.kler.cn/news/155408.html

相关文章:

  • PostgreSQL日志中的SQL记录时机 —— log_statement 和 log_min_duration_statement
  • Session 与 JWT 的对决:谁是身份验证的王者? (下)
  • 中序和前/后序遍历构造二叉树———通用做法
  • 15个Pandas代码片段助力数据分析
  • MySQL索引:优化数据访问的双面剑
  • LeetCode:2336. 无限集中的最小数字(hash模拟 C++)
  • ZooKeeper的分布式锁---客户端命令行测试(实操课程)
  • 9-4 函数输入信息,函数输出信息
  • pytest系列——allure之在测试用例添加标题(@allure.title())
  • KALI LINUX高级话题
  • LeetCode二分查找:x 的平方根
  • 什么是npm?能干什么?
  • 不得不说,HelpLook真的是一个很懂用户的文档管理工具
  • Uniapp
  • 调优--学习笔记
  • SCA技术进阶系列(四):DSDX SBOM供应链安全应用实践
  • 组合总和II(回溯、去重)
  • ROS报错:RLException:Invalid roslaunch XML Syntax: mismatched tag:
  • MFC 绘制单一颜色圆形、渐变颜色边框圆形、渐变填充圆形以及绘制三角函数正弦函数曲线.
  • 【web安全】CSRF漏洞攻击与防御
  • 从零开始:PHP实现阿里云直播的简单方法!
  • Java通过Redis进行延时队列,定时发布消息(根据用户选择时间进行发布)
  • python爬虫抓取网页图片教程
  • Spring事务管理介绍
  • yolo.txt格式与voc格式互转,超详细易上手
  • Centos图形化界面封装OpenStack Ubuntu镜像
  • Electron+Ts+Vue+Vite桌面应用系列:TypeScript常用时间处理工具
  • Python ctypes:揭秘高级Python与底层交互秘籍
  • JavaScript编程基础 – For循环
  • ChatGPT等大语言模型为什么没有智能