两个列表的最小索引总和hashtable

记录酥麻的一天
不知道为什么这题给我中很经典的感觉,发个博就记录一下
真的是 用力去扣题,

在这里插入图片描述

package com.lfweixiao.hashTable;

import java.util.ArrayList;
import java.util.HashMap;

/**
 * @author LFweixiao
 * @create 2022-01-21 下午7:32
 */
public class Solution06 {
    /**
     * 假设Andy和Doris想在晚餐时选择一家餐厅,并且他们都有一个表示最喜爱餐厅的列表,每个餐厅的名字用字符串表示。
     *
     * 你需要帮助他们用最少的索引和找出他们共同喜爱的餐厅。 如果答案不止一个,则输出所有答案并且不考虑顺序。 你可以假设总是存在一个答案。
     */
    public String[] findRestaurant(String[] list1, String[] list2) {
        /**
         * 1.先遍历一个string[]存储到hashmap中
         * 2.然后遍历第二个string[]来对比hashmap中的数,如果有的话就用arraylist存储
         * 3.如果找到arraylist.get(0)中的Index大于新的重复的,这个时候清空arraylist,如果相同就累加
         * 4.得到结果
         */
        HashMap<String, Integer> map = new HashMap<>();
        for(int i =0 ;i< list1.length;++i){
            map.put(list1[i],i);
        }

        ArrayList<String> arr = new ArrayList<>();
        int num = 0;
        for (int i = 0; i < list2.length; i++) {
            if (map.containsKey(list2[i])) {
                //判断数组里面有没有内容
                if (arr.size() == 0) {
                    arr.add(list2[i]);
                    num += i;
                    // 现有值坐标比较小 时
                } else if (map.get(arr.get(0)) + num > map.get(list2[i]) + i) {
                    arr.clear();
                    arr.add(list2[i]);
                } else if (map.get(arr.get(0)) + num == map.get(list2[i]) + i) {
                    arr.add(list2[i]);
                }
            }
        }
        String[] str = new String[arr.size()];
        int i =0;
        for(String s : arr){
            str[i] = s;
            ++i;
        }
        return str;
    }
}

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值