收集垃圾的最少总时间

 
int indexOf(String str)
 返回指定子字符串在此字符串中第一次出现处的索引。

public int indexOf(int ch )

或

public int indexOf(int ch, int fromIndex)

或

int indexOf(String str)

或

int indexOf(String str, int fromIndex)

题目:

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

思路一:遍历每个房子,再遍历房子里的字母。一共有两个耗时:

1、收垃圾的时间:所有字母的长度是收垃圾的时间

2、房子之间的运输时间:计算每个房子的时间。字母在此房子出现,则说明车子需要过来,则更新垃圾车在房子间的运输时间


class Solution {
    public int garbageCollection(String[] garbage, int[] travel) {
        int re=0,tra=0,tmps=0;
#字母长度
         for(String garb :garbage){
             re= re + garb.length();
         }
        HashMap<Character,Integer> map= new HashMap<>();
        for (int i=1;i < garbage.length;i++){
#每个房子:从距离0到此房子的运输距离
            tra=tra+travel[i-1];
#字母出现在此房子中,才更新字母的运输距离
            for (char c : new char[] {'M','G','P'}){
                if(garbage[i].indexOf(c)>=0)  {
                     map.put(c,tra);
                }                                  
                }
            }         
        for (int tmp: map.values()){
            tmps=tmp+tmps;
        }
        return re+tmps;
 
    }
}

思路二:

一共有两个耗时:

1、收垃圾的时间:所有字母的长度是收垃圾的时间

2、房子之间的运输时间:为每辆车设置一个车辆位置变量。当前遍历到房子的位置,如果和车子位置相同,则不加运输时间。如果和车子位置不同,将车子从当前位置,移动到房子位置。

class Solution {
    public int garbageCollection(String[] garbage, int[] travel) {
#设置车辆当前位置
        HashMap<Character,Integer> postmap= new HashMap<>();
        postmap.put('M',0);
        postmap.put('P',0);
        postmap.put('G',0);
        int re=0,tra=0;
#遍历房子
         for (int i=0;i < garbage.length;i++){
            char[] chars=garbage[i].toCharArray();
#遍历房子中的字母
            for (int j=0;j<chars.length;j++){
#判断车辆当前位置是否在房子位置
                if(postmap.get(chars[j])!=i){
#将车辆移到房子位置处
                    for(int tmp=postmap.get(chars[j]);tmp<i;tmp++){
                        tra=tra+travel[tmp];
                    }                   
                    postmap.put(chars[j],i);
                }
                re++;
            }
            }
         return re+tra;

    }
}

思路三:前两个提交之后发现耗时太高了,多个循环嵌套,时间复杂度极高。搜到了一位大佬的解法,不得不说牛逼,大佬就是大佬。

依旧是要算两个耗时,第一个字母遍历都一样。三个思路主要区别都是在房子之间运输时间成本的计算上。

房子之间的运输时间:1、假设三辆垃圾车全部都要走到每一个房子处,计算出三个车子假设走了全程的时间。2、再从后往前遍历房子,看每个字母是否在此房子中出现过,没有则减去这个房子到前一个房子的运输时间。直到每个字母都出现过。

class Solution {
    public int garbageCollection(String[] garbage, int[] travel) {
        int re=0;
        for(String garb :garbage){
             re= re + garb.length();
        }
        for (int tra:travel){
             re=re+3*tra;
        }
        for(char c: new char[] {'G','M','P'}){
            for(int i=garbage.length-1; i>0 && garbage[i].indexOf(c)<0 ;i--){
                re = re -travel[i-1];
           
        }
        }
        
return   re;
    }
    }

  • 8
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值