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

简介: 【5月更文挑战第6天】 收集垃圾的最少总时间

给你一个下标从 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 分钟收拾完所有的纸垃圾。
    收拾玻璃的垃圾车:
  5. 收拾房子 0 的玻璃垃圾
  6. 从房子 0 行驶到房子 1
  7. 从房子 1 行驶到房子 2
  8. 收拾房子 2 的玻璃垃圾
  9. 从房子 2 行驶到房子 3
  10. 收拾房子 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


解题过程:
首先肯定是推导一下样例1

样例一是[G,P,GP,GG],[2,4,3]

思路一:看到题目中说的一辆垃圾车在动或者处理的情况下,其他车不允许移动。那么我就想到,每辆车是相对独立的,就是我可以把三辆车分开算。我们先看车G,遍历一遍每个房子有没有垃圾G,有的话就加上走的路程所需的时间,和房子里垃圾G的数量。没有的话先记录走过来路程所需的时间,为之后有垃圾G做准备。其他垃圾M车,垃圾P车同理


思路二:
通过思路一我想到,因为垃圾处理是固定的1分钟,所以我们可以直接把所以字符的垃圾数量加上,因为不论是G,P,M他们的处理时间都是1分钟,所以处理这么多垃圾的时间肯定就是数量,这个无关于那种垃圾。
然后就是路程问题,我们只需要从后往前看,每种垃圾都是什么时候出现的。加上前缀和就行了。


这两种方法都能解决问题。思路一比较正常的解题方法。思路二是在思路一的基础上进行扩展的方法。反正不管黑猫白猫能抓住耗子的猫就是好猫。能解决问题就行。就当扩展一下思路了。

///思路一
func garbageCollection(garbage []string, travel []int) int {
   
    l:=len(garbage)
    ans:=0
    m:=0
    p:=0
    g:=0
    for i:=0;i<l;i++{
   
        ll:=len(garbage[i])
        for j:=0;j<ll;j++{
   
            if garbage[i][j]=='M'{
   
                ans+=1
                ans+=m
                m=0
            }else if garbage[i][j]=='P'{
   
                ans+=1
                ans+=p
                p=0
            }else if garbage[i][j]=='G'{
   
                ans+=1
                ans+=g
                g=0
            }
        }
        if i!=l-1{
   
            m+=travel[i]
            p+=travel[i]
            g+=travel[i]
        }
    }
    return ans
}
//思路二
func garbageCollection(garbage []string, travel []int) int {
   
    l:=len(garbage)
    ans:=0
    a:=make([]int,l-1)
    for i:=0;i<l-1;i++{
   
        a[i]=travel[i]
        if i!=0{
   
            a[i]+=a[i-1]
        }
    }
    fmt.Println(a)
    p:=0
    m:=0
    g:=0
    for i:=l-1;i>=0;i--{
   
        ll:=len(garbage[i])
        ans+=ll
        if p==1&&m==1&&g==1{
   
            continue
        }
        for j:=0;j<ll;j++{
   
            if p==0&&garbage[i][j]=='P'&&i!=0{
   
                ans+=a[i-1]
                p=1
            }
            if m==0&&garbage[i][j]=='M'&&i!=0{
   
                ans+=a[i-1]
                m=1
            }
            if g==0&&garbage[i][j]=='G'&&i!=0{
   
                ans+=a[i-1]
                g=1
            }
        }
    }
    return ans
}
目录
相关文章
|
Linux Go iOS开发
掌握Go语言:配置环境变量、深入理解GOPATH和GOROOT(1)
掌握Go语言:配置环境变量、深入理解GOPATH和GOROOT(1)
1988 0
|
机器学习/深度学习 传感器 算法
用于准确量化颅面对称性和面部生长的 3D 头影测量方案(Matlab代码实现)
用于准确量化颅面对称性和面部生长的 3D 头影测量方案(Matlab代码实现)
|
10月前
|
JavaScript 前端开发 测试技术
拥抱开源:NestJS 在现代后端开发中的应用
【10月更文挑战第21天】NestJS 是一个基于 TypeScript 的现代 Node.js 框架,结合了 OOP、FP 和 FRP 元素,支持模块化设计、控制器、服务和守卫等核心概念,具备强大的依赖注入系统。本文探讨了 NestJS 的核心特性、应用场景及其在现代后端开发中的价值,包括构建 RESTful API、微服务、单页应用后端和企业级应用。通过最佳实践和社区支持,NestJS 可显著提高开发效率和代码质量。
|
11月前
|
IDE 开发工具
idea控制台出现乱码的解决方案
本文提供了解决IntelliJ IDEA控制台乱码问题的多种方法,包括设置项目编码、控制台编码、修改启动配置、修改IDE编码、检查系统环境设置以及更新IDE版本。
1639 0
|
前端开发
Vue+ElementUI前端添加展开收起搜索框按钮
Vue+ElementUI前端添加展开收起搜索框按钮
714 0
|
JavaScript Java 测试技术
基于ssm+vue.js医院住院综合服务管理系统的附带文章和源代码设计说明文档ppt
基于ssm+vue.js医院住院综合服务管理系统的附带文章和源代码设计说明文档ppt
78 1
|
JavaScript Java 测试技术
基于SpringBoot+Vue+uniapp的校园线上订餐系统的详细设计和实现(源码+lw+部署文档+讲解等)
基于SpringBoot+Vue+uniapp的校园线上订餐系统的详细设计和实现(源码+lw+部署文档+讲解等)
136 0
|
存储 JSON 运维
聊聊日志硬扫描,阿里 Log Scan 的设计与实践
SLS 新推出 Scan 功能,让未索引的字段也支持搜索(硬扫描模式),节省全量索引产生的构建和存储费用,同时 Scan 的运行时计算模式对于杂乱结构的日志数据有更好的适配,帮助企业客户实现数字化增效、IT 支出降本的目标。
14289 9
聊聊日志硬扫描,阿里 Log Scan 的设计与实践
Java 日期格式化工具类
import java.text.ParseException; import java.text.SimpleDateFormat; import java.util.Calendar; import java.
1683 0
|
JavaScript
vue3不在手动引入import {ref} from ‘vue‘ 等 也能照样运行项目(unplugin-auto-import)
vue3不在手动引入import {ref} from ‘vue‘ 等 也能照样运行项目(unplugin-auto-import)
818 0