力扣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

相关文章

详解Java如何向http/https接口发出请求

《详解Java如何向http/https接口发出请求》这篇文章主要为大家详细介绍了Java如何实现向http/https接口发出请求,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 用Java发送web请求所用到的包都在java.net下,在具体使用时可以用如下代码,你可以把它封装成一

SpringBoot使用Apache Tika检测敏感信息

《SpringBoot使用ApacheTika检测敏感信息》ApacheTika是一个功能强大的内容分析工具,它能够从多种文件格式中提取文本、元数据以及其他结构化信息,下面我们来看看如何使用Ap... 目录Tika 主要特性1. 多格式支持2. 自动文件类型检测3. 文本和元数据提取4. 支持 OCR(光学

Java内存泄漏问题的排查、优化与最佳实践

《Java内存泄漏问题的排查、优化与最佳实践》在Java开发中,内存泄漏是一个常见且令人头疼的问题,内存泄漏指的是程序在运行过程中,已经不再使用的对象没有被及时释放,从而导致内存占用不断增加,最终... 目录引言1. 什么是内存泄漏?常见的内存泄漏情况2. 如何排查 Java 中的内存泄漏?2.1 使用 J

JAVA系统中Spring Boot应用程序的配置文件application.yml使用详解

《JAVA系统中SpringBoot应用程序的配置文件application.yml使用详解》:本文主要介绍JAVA系统中SpringBoot应用程序的配置文件application.yml的... 目录文件路径文件内容解释1. Server 配置2. Spring 配置3. Logging 配置4. Ma

Java 字符数组转字符串的常用方法

《Java字符数组转字符串的常用方法》文章总结了在Java中将字符数组转换为字符串的几种常用方法,包括使用String构造函数、String.valueOf()方法、StringBuilder以及A... 目录1. 使用String构造函数1.1 基本转换方法1.2 注意事项2. 使用String.valu

java脚本使用不同版本jdk的说明介绍

《java脚本使用不同版本jdk的说明介绍》本文介绍了在Java中执行JavaScript脚本的几种方式,包括使用ScriptEngine、Nashorn和GraalVM,ScriptEngine适用... 目录Java脚本使用不同版本jdk的说明1.使用ScriptEngine执行javascript2.

Spring MVC如何设置响应

《SpringMVC如何设置响应》本文介绍了如何在Spring框架中设置响应,并通过不同的注解返回静态页面、HTML片段和JSON数据,此外,还讲解了如何设置响应的状态码和Header... 目录1. 返回静态页面1.1 Spring 默认扫描路径1.2 @RestController2. 返回 html2

Spring常见错误之Web嵌套对象校验失效解决办法

《Spring常见错误之Web嵌套对象校验失效解决办法》:本文主要介绍Spring常见错误之Web嵌套对象校验失效解决的相关资料,通过在Phone对象上添加@Valid注解,问题得以解决,需要的朋... 目录问题复现案例解析问题修正总结  问题复现当开发一个学籍管理系统时,我们会提供了一个 API 接口去

Java操作ElasticSearch的实例详解

《Java操作ElasticSearch的实例详解》Elasticsearch是一个分布式的搜索和分析引擎,广泛用于全文搜索、日志分析等场景,本文将介绍如何在Java应用中使用Elastics... 目录简介环境准备1. 安装 Elasticsearch2. 添加依赖连接 Elasticsearch1. 创

Spring核心思想之浅谈IoC容器与依赖倒置(DI)

《Spring核心思想之浅谈IoC容器与依赖倒置(DI)》文章介绍了Spring的IoC和DI机制,以及MyBatis的动态代理,通过注解和反射,Spring能够自动管理对象的创建和依赖注入,而MyB... 目录一、控制反转 IoC二、依赖倒置 DI1. 详细概念2. Spring 中 DI 的实现原理三、