• leetcode 收集垃圾的最少总时间


    给你一个下标从 0 开始的字符串数组 garbage ,其中 garbage[i] 表示第 i 个房子的垃圾集合。garbage[i] 只包含字符 'M' ,'P' 和 'G' ,但可能包含多个相同字符,每个字符分别表示一单位的金属、纸和玻璃。垃圾车收拾  单位的任何一种垃圾都需要花费 1 分钟。

    同时给你一个下标从 0 开始的整数数组 travel ,其中 travel[i] 是垃圾车从房子 i 行驶到房子 i + 1 需要的分钟数。

    城市里总共有三辆垃圾车,分别收拾三种垃圾。每辆垃圾车都从房子 0 出发,按顺序 到达每一栋房子。但它们 不是必须 到达所有的房子。

    任何时刻只有 一辆 垃圾车处在使用状态。当一辆垃圾车在行驶或者收拾垃圾的时候,另外两辆车 不能 做任何事情。

    请你返回收拾完所有垃圾需要花费的 最少 总分钟数。

    示例 1:

    输入:garbage = ["G","P","GP","GG"], travel = [2,4,3]
    输出:21
    解释:
    收拾纸的垃圾车:
    1. 从房子 0 行驶到房子 1
    2. 收拾房子 1 的纸垃圾
    3. 从房子 1 行驶到房子 2
    4. 收拾房子 2 的纸垃圾
    收拾纸的垃圾车总共花费 8 分钟收拾完所有的纸垃圾。
    收拾玻璃的垃圾车:
    1. 收拾房子 0 的玻璃垃圾
    2. 从房子 0 行驶到房子 1
    3. 从房子 1 行驶到房子 2
    4. 收拾房子 2 的玻璃垃圾
    5. 从房子 2 行驶到房子 3
    6. 收拾房子 3 的玻璃垃圾
    收拾玻璃的垃圾车总共花费 13 分钟收拾完所有的玻璃垃圾。
    由于没有金属垃圾,收拾金属的垃圾车不需要花费任何时间。
    所以总共花费 8 + 13 = 21 分钟收拾完所有垃圾。
    

    示例 2:

    输入:garbage = ["MMM","PGM","GP"], travel = [3,10]
    输出:37
    解释:
    收拾金属的垃圾车花费 7 分钟收拾完所有的金属垃圾。
    收拾纸的垃圾车花费 15 分钟收拾完所有的纸垃圾。
    收拾玻璃的垃圾车花费 15 分钟收拾完所有的玻璃垃圾。
    总共花费 7 + 15 + 15 = 37 分钟收拾完所有的垃圾。
    

    提示:

    • 2 <= garbage.length <= 105
    • garbage[i] 只包含字母 'M' ,'P' 和 'G' 。
    • 1 <= garbage[i].length <= 10
    • travel.length == garbage.length - 1
    • 1 <= travel[i] <= 100

    C++

    1. class Solution {
    2. public:
    3. int getNum(int idx) {
    4. int ans=0;
    5. for(int i=0;i<=idx;i++) {
    6. ans+=travel[i];
    7. }
    8. return ans;
    9. }
    10. int garbageCollection(vector& garbage, vector<int>& travel) {
    11. this->travel=travel;
    12. int res=0;
    13. int a,b,c=0;
    14. int n=garbage.size();
    15. for(int i=0;i
    16. if(garbage[i].find('M')!=std::string::npos) {
    17. a=i;
    18. }
    19. if(garbage[i].find('P')!=std::string::npos) {
    20. b=i;
    21. }
    22. if(garbage[i].find('G')!=std::string::npos) {
    23. c=i;
    24. }
    25. }
    26. a--;
    27. b--;
    28. c--;
    29. for(int i=0;i
    30. res+=garbage[i].size();
    31. }
    32. return res+getNum(a)+getNum(b)+getNum(c);
    33. }
    34. private:
    35. vector<int> travel;
    36. };

  • 相关阅读:
    软考 系统架构设计师 简明教程 | 系统运行与软件维护
    Linux系统编程(五)——Linux下的多线程
    阿里大佬耗时一年整理的 Java 面试常考题,GitHub 点赞 33K+
    硬件信息查看工具 EtreCheckpro mac中文版功能介绍
    目标检测系列——开山之作RCNN原理详解
    electron 应用开发优秀实践
    MySQL —— 索引
    寄存器(汇编语言)
    python (语音)信号拆分为数据块,计算短期能量和过零率
    【Kotlin 协程】协程的挂起和恢复 ② ( 协程挂起 和 线程阻塞 对比 )
  • 原文地址:https://blog.csdn.net/qq_27060423/article/details/126576098