给你一个下标从 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 <= 105garbage[i] 只包含字母 'M' ,'P' 和 'G' 。1 <= garbage[i].length <= 10travel.length == garbage.length - 11 <= travel[i] <= 100C++
- class Solution {
- public:
- int getNum(int idx) {
- int ans=0;
- for(int i=0;i<=idx;i++) {
- ans+=travel[i];
- }
- return ans;
- }
-
- int garbageCollection(vector
& garbage, vector<int>& travel) { - this->travel=travel;
- int res=0;
- int a,b,c=0;
- int n=garbage.size();
- for(int i=0;i
- if(garbage[i].find('M')!=std::string::npos) {
- a=i;
- }
- if(garbage[i].find('P')!=std::string::npos) {
- b=i;
- }
- if(garbage[i].find('G')!=std::string::npos) {
- c=i;
- }
- }
- a--;
- b--;
- c--;
- for(int i=0;i
- res+=garbage[i].size();
- }
- return res+getNum(a)+getNum(b)+getNum(c);
- }
- private:
- vector<int> travel;
- };
-
相关阅读:
赋值 响应式问题
Pinia 是否可以代替 Vuex ?
2024.3.11 C++作业
MyEclipse 新手使用教程
《Java 核心技术卷1 基础知识》第一章 Java程序设计概述 笔记
LeetCode 热题 C++ 75. 颜色分类
Eureka注册中心
红光光浴-改善亚健康状态
Java也能做OCR!SpringBoot 整合 Tess4J 实现图片文字识别
python--函数
-
原文地址:https://blog.csdn.net/qq_27060423/article/details/126576098