LeetCode 2391. 收集垃圾的最少总时间

Problem: 2391. 收集垃圾的最少总时间

问题分解

我们将这个问题分解为以下几个小问题:

  1. 计算每种垃圾(金属、纸、玻璃)在每个房子中的数量。
  2. 确定每种垃圾车最后到达的房子。
  3. 计算每种垃圾车行驶的总时间。
  4. 计算每种垃圾车收拾垃圾的总时间。
  5. 返回所有垃圾车花费时间的总和。

解决问题

现在让我们逐步解答这些问题:

问题1:计算每种垃圾在每个房子中的数量?

我们可以遍历每个房子的垃圾字符串,统计每种垃圾的数量。

问题2:确定每种垃圾车最后到达的房子?

我们可以在统计垃圾数量的同时,记录每种垃圾车最后到达的房子。

问题3:计算每种垃圾车行驶的总时间?

我们需要遍历travel数组,对于每种垃圾车,如果当前房子不是它最后到达的房子,那么它需要行驶到下一个房子。

问题4:计算每种垃圾车收拾垃圾的总时间?

在统计垃圾数量的过程中,我们已经计算了每种垃圾车收拾垃圾的总时间。

问题5:返回所有垃圾车花费时间的总和?

我们将每种垃圾车的行驶时间和收拾垃圾的时间相加,得到每种垃圾车的总时间,然后将这些时间相加得到最终答案。

解题答案

根据以上分析,我们可以实现以下代码:

cpp 复制代码
class Solution {
public:
    int garbageCollection(vector<string>& garbage, vector<int>& travel) {
        int n = garbage.size();
        int metalTime = 0, paperTime = 0, glassTime = 0;
        int metalLastHouse = 0, paperLastHouse = 0, glassLastHouse = 0;
        
        // 统计每种垃圾的数量和最后到达的房子
        for (int i = 0; i < n; ++i) {
            for (char c : garbage[i]) {
                if (c == 'M') {
                    metalTime++;
                    metalLastHouse = i;
                } else if (c == 'P') {
                    paperTime++;
                    paperLastHouse = i;
                } else if (c == 'G') {
                    glassTime++;
                    glassLastHouse = i;
                }
            }
        }
        
        // 计算每种垃圾车的行驶时间
        for (int i = 0; i < n - 1; ++i) {
            if (i < metalLastHouse) {
                metalTime += travel[i];
            }
            if (i < paperLastHouse) {
                paperTime += travel[i];
            }
            if (i < glassLastHouse) {
                glassTime += travel[i];
            }
        }
        
        // 返回总时间
        return metalTime + paperTime + glassTime;
    }
};

这段代码首先统计了每种垃圾的数量和最后到达的房子,然后计算了每种垃圾车的行驶时间,最后返回了总时间。这个解法的时间复杂度是O(n),其中n是房子的数量。

相关推荐
2301_8227032016 小时前
Flutter 框架跨平台鸿蒙开发 - 创意声音合成器应用
算法·flutter·华为·harmonyos·鸿蒙
zhaoshuzhaoshu16 小时前
人工智能(AI)发展史:详细里程碑
人工智能·职场和发展
cmpxr_16 小时前
【C】数组名、函数名的特殊
c语言·算法
KAU的云实验台16 小时前
【算法精解】AIR期刊算法IAGWO:引入速度概念与逆多元二次权重,可应对高维/工程问题(附Matlab源码)
开发语言·算法·matlab
会编程的土豆16 小时前
【数据结构与算法】再次全面了解LCS底层
开发语言·数据结构·c++·算法
大熊背17 小时前
如何利用Lv值实现三级降帧
算法·自动曝光·lv·isppipeline
大尚来也17 小时前
驾驭并发:.NET多线程编程的挑战与破局之道
java·前端·算法
向阳而生,一路生花18 小时前
深入浅出 JDK7 HashMap 源码分析
算法·哈希算法
君义_noip18 小时前
信息学奥赛一本通 4150:【GESP2509七级】⾦币收集 | 洛谷 P14078 [GESP202509 七级] 金币收集
c++·算法·gesp·信息学奥赛·csp-s
摸个小yu18 小时前
【力扣LeetCode热题h100】链表、二叉树
算法·leetcode·链表