记录酥麻的一天
不知道为什么这题给我中很经典的感觉,发个博就记录一下
真的是 用力去扣题,
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;
}
}