LeetCode 每日一题 Day1

1094. 拼车

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

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

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

示例 1:

输入:trips = [[2,1,5],[3,3,7]], capacity = 4

输出:false

示例 2:

输入:trips = [[2,1,5],[3,3,7]], capacity = 5

输出:true

提示:

1 <= trips.length <= 1000

trips[i].length == 3

1 <= numPassengersi <= 100

0 <= fromi < toi <= 1000

1 <= capacity <= 105

我的代码实现如下,使用了差分法:

复制代码
#include <iostream>
#include <vector>

bool carPooling(std::vector<std::vector<int>>& trips, int capacity) {
    const int maxLocation = 1001; // 最大位置数,根据题目要求设定

    // 创建差分数组,初始化为0
    std::vector<int> diff(maxLocation, 0);

    // 更新差分数组
    for (const auto& trip : trips) {
        diff[trip[1]] += trip[0]; // 乘客在 fromi 上车
        diff[trip[2]] -= trip[0]; // 乘客在 toi 下车
    }

    // 模拟行车过程,并实时检查是否超过最大载客量
    int currentPassengers = 0;
    for (int i = 0; i < maxLocation; ++i) {
        currentPassengers += diff[i];
        if (currentPassengers > capacity) {
            return false; // 在某个时刻超过了最大载客量
        }
    }

    return true;
}

int main() {
    std::vector<std::vector<int>> trips = {{4, 5, 6}, {6, 4, 7}, {4, 3, 5}, {2, 3, 5}};
    int capacity = 13;
    bool result = carPooling(trips, capacity);
    std::cout << std::boolalpha << result << std::endl; // 输出 true

    return 0;
}

在这里给出了完整代码,至于使用差分法,是因为它可以高效处理数组元素的区间修改,正好与该题对应,使用迭代差分即可ac

相关推荐
ofoxcoding12 分钟前
GPT-5.4 API 完全指南:性能实测、成本测算与接入方案(2026)
人工智能·gpt·算法·ai
码农的神经元13 分钟前
基于改进 VMD 与自适应小波的水声信号去噪算法实现与分析
算法
tankeven32 分钟前
HJ156 走迷宫
c++·算法
旺仔.2911 小时前
STL排序算法详解
数据结构·算法·排序算法
酉鬼女又兒1 小时前
零基础快速入门前端蓝桥杯Web备考:BOM与定时器核心知识点详解(可用于备赛蓝桥杯Web应用开发)
开发语言·前端·javascript·职场和发展·蓝桥杯
美狐美颜sdk1 小时前
美颜SDK是什么?直播/短视频美颜SDK技术详解
人工智能·算法·美颜sdk·直播美颜sdk·美颜api
华农DrLai1 小时前
什么是远程监督?怎么自动生成训练数据?
人工智能·算法·llm·prompt·知识图谱
计算机安禾1 小时前
【数据结构与算法】第16篇:串(String)的定长顺序存储与朴素模式匹配
c语言·数据结构·c++·学习·算法·visual studio code·visual studio
Roselind_Yi1 小时前
【吴恩达2026 Agentic AI】面试向+项目实战(含面试题+项目案例)-2
人工智能·python·机器学习·面试·职场和发展·langchain·agent
AI科技星1 小时前
基于v≡c公设的理论优化方案
c语言·开发语言·算法·机器学习·数据挖掘