本文介绍: 给定整数 capacity一个数组 trips , trip[i] = [numPassengersi, fromi, toi] 表示i 次旅行有 numPassengersi 乘客,接他们和放他们位置分别是 fromi 和 toi。当且仅当你可以在所有给定的行程中接送所有乘客时,返回 true,否则请返回 false输入trips = [[2,1,5],[3,3,7]], capacity = 4。输入trips = [[2,1,5],[3,3,7]], capacity = 5。

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 &lt;= trips.length <= 1000
trips[i].length == 3
1 <= numPassengersi <= 100
0 <= fromi < toi <= 1000
1 <= capacity <= 105

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

#include <iostream&gt;
#include <vector&gt;

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

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

    // 更新分数组
    for (const auto&amp; 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

原文地址:https://blog.csdn.net/m0_73814009/article/details/134747862

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任

如若转载,请注明出处:http://www.7code.cn/show_34336.html

如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱suwngjj01@126.com进行投诉反馈,一经查实,立即删除

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注