comments | difficulty | edit_url | rating | source | tags | |||
---|---|---|---|---|---|---|---|---|
true |
中等 |
1455 |
第 308 场周赛 Q3 |
|
给你一个下标从 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
根据题目描述,每一辆垃圾车从房子
因此,我们可以用一个哈希表
时间复杂度
class Solution:
def garbageCollection(self, garbage: List[str], travel: List[int]) -> int:
last = {}
ans = 0
for i, s in enumerate(garbage):
ans += len(s)
for c in s:
last[c] = i
ts = 0
for i, t in enumerate(travel, 1):
ts += t
ans += sum(ts for j in last.values() if i == j)
return ans
class Solution {
public int garbageCollection(String[] garbage, int[] travel) {
Map<Character, Integer> last = new HashMap<>(3);
int ans = 0;
for (int i = 0; i < garbage.length; ++i) {
String s = garbage[i];
ans += s.length();
for (char c : s.toCharArray()) {
last.put(c, i);
}
}
int ts = 0;
for (int i = 1; i <= travel.length; ++i) {
ts += travel[i - 1];
for (int j : last.values()) {
if (i == j) {
ans += ts;
}
}
}
return ans;
}
}
class Solution {
public:
int garbageCollection(vector<string>& garbage, vector<int>& travel) {
unordered_map<char, int> last;
int ans = 0;
for (int i = 0; i < garbage.size(); ++i) {
auto& s = garbage[i];
ans += s.size();
for (char& c : s) {
last[c] = i;
}
}
int ts = 0;
for (int i = 1; i <= travel.size(); ++i) {
ts += travel[i - 1];
for (auto& [_, j] : last) {
if (i == j) {
ans += ts;
}
}
}
return ans;
}
};
func garbageCollection(garbage []string, travel []int) (ans int) {
last := map[byte]int{}
for i, s := range garbage {
ans += len(s)
for j := range s {
last[s[j]] = i
}
}
ts := 0
for i := 1; i <= len(travel); i++ {
ts += travel[i-1]
for _, j := range last {
if i == j {
ans += ts
}
}
}
return
}
function garbageCollection(garbage: string[], travel: number[]): number {
const last: Map<string, number> = new Map();
let ans = 0;
for (let i = 0; i < garbage.length; ++i) {
const s = garbage[i];
ans += s.length;
for (const c of s) {
last.set(c, i);
}
}
let ts = 0;
for (let i = 1; i <= travel.length; ++i) {
ts += travel[i - 1];
for (const [_, j] of last) {
if (i === j) {
ans += ts;
}
}
}
return ans;
}
use std::collections::HashMap;
impl Solution {
pub fn garbage_collection(garbage: Vec<String>, travel: Vec<i32>) -> i32 {
let mut last: HashMap<char, usize> = HashMap::new();
let mut ans = 0;
for (i, s) in garbage.iter().enumerate() {
ans += s.len() as i32;
for c in s.chars() {
last.insert(c, i);
}
}
let mut ts = 0;
for (i, t) in travel.iter().enumerate() {
ts += t;
for &j in last.values() {
if i + 1 == j {
ans += ts;
}
}
}
ans
}
}
public class Solution {
public int GarbageCollection(string[] garbage, int[] travel) {
Dictionary<char, int> last = new Dictionary<char, int>();
int ans = 0;
for (int i = 0; i < garbage.Length; ++i) {
ans += garbage[i].Length;
foreach (char c in garbage[i]) {
last[c] = i;
}
}
int ts = 0;
for (int i = 1; i <= travel.Length; ++i) {
ts += travel[i - 1];
foreach (int j in last.Values) {
if (i == j) {
ans += ts;
}
}
}
return ans;
}
}