力扣2391---收集垃圾的最少总时间(Java、前缀和)

2024-05-12 07:12

本文主要是介绍力扣2391---收集垃圾的最少总时间(Java、前缀和),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

题目描述:

思路描述:

代码:

        最笨的方法:

        较好的方法:


题目描述:

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

思路描述:

        依据题目的意思,我们可以得出收集垃圾的最少总时间就是让每个车不浪费多余的时间,即某一个车到达一个位置后,如果该位置以后都没有属于自己收集的垃圾类型,就不再消耗时间去遍历。

        最笨的方法就是多次遍历得到结果。

        较好的方法就是一次遍历得到结果,在计算三辆车总的时间时,对于第一部分,可直接对 garbage\textit{garbage}garbage 中所有字符串的长度求和;对于第二部分,可以求出每辆车到达每类垃圾最后一次出现的位置所消耗的时间,最后进行求和。

        在第二部分进行代码实现时,可用一个变量维护 travel的前缀和。

代码:

        最笨的方法:

public int garbageCollection(String[] garbage, int[] travel) {int ans=0;int n=garbage.length;int m=travel.length;int[] lastIndex={-1,-1,-1};int[] threeSum={0,0,0};List<Map<Character,Integer>> list=new ArrayList<>();for(int i=0;i<n;i++){if (garbage[i].contains("M")) {lastIndex[0]=i;}if (garbage[i].contains("P")) {lastIndex[1]=i;}if (garbage[i].contains("G")) {lastIndex[2]=i;}char[] charArray = garbage[i].toCharArray();int len=charArray.length;Map<Character,Integer> map=new HashMap<>();map.put('M',0);map.put('P',0);map.put('G',0);for (int j=0;j<len;j++){map.put(charArray[j],map.get(charArray[j])+1);}list.add(map);}for (int i = 0; i < 3; i++) {if(lastIndex[i]==-1){continue;} else if (lastIndex[i] == 0) {Map<Character, Integer> map = list.get(0);if(i==0){ans+=map.get('M');} else if (i==1) {ans+=map.get('P');}else{ans+=map.get('G');}continue;}for(int j=0;j<lastIndex[i];){Map<Character, Integer> map = list.get(j);if(i==0){ans+=map.get('M');} else if (i==1) {ans+=map.get('P');}else{ans+=map.get('G');}ans+=travel[j];j++;if(j==lastIndex[i]){Map<Character, Integer> map2 = list.get(j);if(i==0){ans+=map2.get('M');} else if (i==1) {ans+=map2.get('P');}else{ans+=map2.get('G');}}}}return ans;}

        较好的方法:

class Solution {public int garbageCollection(String[] garbage, int[] travel) {int ans=0;int n=garbage.length;int[] distance=new int[n];int[] lastIndex={-1,-1,-1};for(int i=0;i<n;i++){if(i>0){distance[i]=distance[i-1]+travel[i-1];}ans+=garbage[i].length();if (garbage[i].contains("M")) {lastIndex[0]=i;}if (garbage[i].contains("P")) {lastIndex[1]=i;}if (garbage[i].contains("G")) {lastIndex[2]=i;}}for(int i=0;i<3;i++){if(lastIndex[i]==-1){continue;}else{ans+=distance[lastIndex[i]];}}return ans;}
}

这篇关于力扣2391---收集垃圾的最少总时间(Java、前缀和)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/981950

相关文章

Spring Boot循环依赖原理、解决方案与最佳实践(全解析)

《SpringBoot循环依赖原理、解决方案与最佳实践(全解析)》循环依赖指两个或多个Bean相互直接或间接引用,形成闭环依赖关系,:本文主要介绍SpringBoot循环依赖原理、解决方案与最... 目录一、循环依赖的本质与危害1.1 什么是循环依赖?1.2 核心危害二、Spring的三级缓存机制2.1 三

在Spring Boot中浅尝内存泄漏的实战记录

《在SpringBoot中浅尝内存泄漏的实战记录》本文给大家分享在SpringBoot中浅尝内存泄漏的实战记录,结合实例代码给大家介绍的非常详细,感兴趣的朋友一起看看吧... 目录使用静态集合持有对象引用,阻止GC回收关键点:可执行代码:验证:1,运行程序(启动时添加JVM参数限制堆大小):2,访问 htt

SpringBoot集成Milvus实现数据增删改查功能

《SpringBoot集成Milvus实现数据增删改查功能》milvus支持的语言比较多,支持python,Java,Go,node等开发语言,本文主要介绍如何使用Java语言,采用springboo... 目录1、Milvus基本概念2、添加maven依赖3、配置yml文件4、创建MilvusClient

浅析Java中如何优雅地处理null值

《浅析Java中如何优雅地处理null值》这篇文章主要为大家详细介绍了如何结合Lambda表达式和Optional,让Java更优雅地处理null值,感兴趣的小伙伴可以跟随小编一起学习一下... 目录场景 1:不为 null 则执行场景 2:不为 null 则返回,为 null 则返回特定值或抛出异常场景

SpringMVC获取请求参数的方法

《SpringMVC获取请求参数的方法》:本文主要介绍SpringMVC获取请求参数的方法,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下... 目录1、通过ServletAPI获取2、通过控制器方法的形参获取请求参数3、@RequestParam4、@

SpringBoot应用中出现的Full GC问题的场景与解决

《SpringBoot应用中出现的FullGC问题的场景与解决》这篇文章主要为大家详细介绍了SpringBoot应用中出现的FullGC问题的场景与解决方法,文中的示例代码讲解详细,感兴趣的小伙伴可... 目录Full GC的原理与触发条件原理触发条件对Spring Boot应用的影响示例代码优化建议结论F

springboot项目中常用的工具类和api详解

《springboot项目中常用的工具类和api详解》在SpringBoot项目中,开发者通常会依赖一些工具类和API来简化开发、提高效率,以下是一些常用的工具类及其典型应用场景,涵盖Spring原生... 目录1. Spring Framework 自带工具类(1) StringUtils(2) Coll

SpringBoot条件注解核心作用与使用场景详解

《SpringBoot条件注解核心作用与使用场景详解》SpringBoot的条件注解为开发者提供了强大的动态配置能力,理解其原理和适用场景是构建灵活、可扩展应用的关键,本文将系统梳理所有常用的条件注... 目录引言一、条件注解的核心机制二、SpringBoot内置条件注解详解1、@ConditionalOn

通过Spring层面进行事务回滚的实现

《通过Spring层面进行事务回滚的实现》本文主要介绍了通过Spring层面进行事务回滚的实现,包括声明式事务和编程式事务,具有一定的参考价值,感兴趣的可以了解一下... 目录声明式事务回滚:1. 基础注解配置2. 指定回滚异常类型3. ​不回滚特殊场景编程式事务回滚:1. ​使用 TransactionT

Spring LDAP目录服务的使用示例

《SpringLDAP目录服务的使用示例》本文主要介绍了SpringLDAP目录服务的使用示例... 目录引言一、Spring LDAP基础二、LdapTemplate详解三、LDAP对象映射四、基本LDAP操作4.1 查询操作4.2 添加操作4.3 修改操作4.4 删除操作五、认证与授权六、高级特性与最佳