首页 > 其他分享 >2391. 收集垃圾的最少总时间

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

时间:2024-05-11 19:52:05浏览次数:21  
标签:垃圾车 garbage travel 房子 最少 垃圾 2391 收拾

传送锚点:https://leetcode.cn/problems/minimum-amount-of-time-to-collect-garbage/description/

给你一个下标从 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 分钟收拾完所有的垃圾。

思路

时间分为垃圾车到每间房子的时间和垃圾车处理垃圾的时间

Code 1

class Solution {
public:
    int garbageCollection(vector<string>& garbage, vector<int>& travel) {
        map<char,int> mp;//记录垃圾离起始点最远位置
        mp['W'] = 0, mp['G'] = 0, mp['P'] = 0;
        int time_pick = 0;//捡垃圾的时间
        for(int i = 0; i < garbage.size(); i++){//遍历每间房子所含的垃圾种类
            time_pick += garbage[i].size();
            for(char c : {'G', 'P', 'M'}){
                if(garbage[i].find(c) != string::npos){
                    mp[c] = i;
                }
            }
        }
        int time_arrive = 0;
        for(auto pair : mp){
            int pos = pair.second;//垃圾最后出现的位置
            time_arrive += accumulate(travel.begin(), travel.begin() + pos, 0 );
        }
        return time_pick +  time_arrive;
    }
};

Code 2

class Solution {
public:
    int garbageCollection(vector<string>& garbage, vector<int>& travel) {
        //灵神的一次遍历,方法太nice了,通过从最远房子开始计算贡献值
        //路段数比房子数少1
        unordered_set<char> visit;
        int ans = garbage[0].size();
        for(int i = garbage.size() - 1; i; i--){
            auto &g = garbage[i];
            visit.insert(g.begin(), g.end());
            ans += g.size() + visit.size() * travel[i-1];
        }
        return ans;
    }
};

标签:垃圾车,garbage,travel,房子,最少,垃圾,2391,收拾
From: https://www.cnblogs.com/6Luffy6/p/18187092

相关文章

  • jvm内存模型、垃圾回收机制
    JVM内存模型JVM内存模型包括:线程计数器、本地方法栈、栈、堆、方法区(元空间),类装载子系统,字节码执行引擎。线程计数器线程启动时,程序技术会分配一小块空间分配给当前线程,每个线程都会独享一块程序计数器空间,用于存储下条指令的单元地址程序计数器是一块较小的内存空间,用于......
  • CMS垃圾收集器深入解析
    CMS本身是个非常极端的垃圾收集器,他过于注重停顿时间,而不在乎吞吐量。正常情况使用标记清除算法,所以也会有内存碎片的产生,整个CMS垃圾收集的过程,主要是为了缩短停顿时间,所以在有些环节会与业务线程并发执行。1.初始标记,根据GCRoot的引用链,只标记第一个对象,此时是多个标记线程并......
  • 析构方法和垃圾回收器
    //垃圾回收机制://回收非托管资源--Windows窗口句柄,数据库的链接,GDI对象,独占文件锁等等对象//1.Dispose()需要实现IDisposable接口//2.Close()和Dispose()的区别--Close关闭对象,没有完全释放(可以再次使用)。Dispose完全释放(再次使用重新创建)。//析构方法//......
  • Centos7搭建本地yum源(最少步骤)
    Centos7搭建本地yum源(最少步骤)配置本地yum源一、部署磁盘1、查看磁盘是否已连接2、查看磁盘所属的盘符lsblk这里的磁盘名称都在/dev下面的。3、挂载和永久挂载挂载前要创建挂载文件(这里就挂载到/mnt/dvd吧)mkdir/mnt/dvd(1)挂载mount/dev/sr0/mnt/dvd(2)永久挂载需......
  • 2024-04-27:用go语言,在一个下标从 1 开始的 8 x 8 棋盘上,有三个棋子,分别是白色车、白色
    2024-04-27:用go语言,在一个下标从1开始的8x8棋盘上,有三个棋子,分别是白色车、白色象和黑色皇后。给定这三个棋子的位置,请计算出要捕获黑色皇后所需的最少移动次数。需要注意的是,白色车可以垂直或水平移动,而白色象可以沿对角线移动,它们不能跳过其他棋子。如果白色车或白色象......
  • HJ23 删除字符串中出现次数最少的字符
    利用list的排序来得到最小次数的字符,其中需要注意对map做深拷贝!卡了很久,因为不知道如何处理最小这一点publicclassMain{publicstaticvoidmain(String[]args){Scannerin=newScanner(System.in);//注意hasNext和hasNextLine的区别......
  • 挑战前端基础120题--垃圾回收机制?
    1.什么是垃圾回收机制?简称GC,内存管理自动运行,找到不被使用的变量,进行垃圾回收释放内存;补充点:JS变量分为:全局变量&局部变量;全局变量的生命周期是一直存在直到页面被销毁。局部变量一般定义在函数内部,他的生命周期从函数被调用开始,直到函数运行结束。等到局部变量不被使用,就......
  • 35天【代码随想录算法训练营34期】第八章 贪心算法 part04 ( ● 860.柠檬水找零 ● 4
    860.柠檬水找零classSolution:deflemonadeChange(self,bills:List[int])->bool:amt_five=0amt_ten=0amt_twenty=0foriinbills:ifi==5:amt_five+=1elifi==10:......
  • Advanced .Net Debugging 7:托管堆与垃圾收集
    一、简介这是我的《Advanced.NetDebugging》这个系列的第七篇文章。这篇文章的内容是原书的第二部分的【调试实战】的第五章,这一章主要讲的是从根本上认识托管堆和垃圾回收。软件系统的内存管理方式有两种,第一种是手动管理内存,这种方式容易产生一些问题产生,比如:悬空指针......
  • 边缘计算智能分析网关V4地面垃圾AI检测算法介绍及场景应用
    在传统的卫生监管场景中,无法及时发现地面遗留的垃圾,通过人工巡逻的方式需要大量的人力、物力和时间,而且效率不高,并存在一定的滞后性,而采用地面垃圾AI检测算法则可以大大提高监管效率。TSINGSEE青犀AI智能分析网关V4的地面垃圾AI检测算法可以自动识别划定区域内遗留的垃圾,若达到设......