-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path599-findRestaurant.go
97 lines (92 loc) · 2.55 KB
/
599-findRestaurant.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
// https://leetcode-cn.com/problems/minimum-index-sum-of-two-lists/
package main
import (
"fmt"
)
/**
* 思路:为了控制索引和最小,从小到大遍历索引和
* 时间 O((l1+l2)*l1*r) l1/l2 表示list1/list2 长度,x 表示字符串平均长度
* 空间 O(1)
*/
func findRestaurant(list1 []string, list2 []string) []string {
ret := []string{}
for sum := 0; sum <= len(list1)+len(list2)-2; sum++ { // sum 表示索引和,从最小索引开始向上遍历
for i, j := 0, sum; i < len(list1) && j >= 0; {
if j < len(list2) && list1[i] == list2[j] {
ret = append(ret, list1[i])
}
i++
j = sum - i
}
if len(ret) > 0 {
break
}
}
return ret
}
/**
* 官方解答一,利用哈希表缓存
* 时间 O(l1 ∗l2 ∗x)。l1和 l2 是 list1 和 list2的长度,x 是字符串的平均长度。
* 空间 O(l1 *l2 *x)
*/
func findRestaurant2(list1 []string, list2 []string) []string {
m := map[int][]string{}
for i := 0; i < len(list1); i++ {
for j := 0; j < len(list2); j++ {
if list1[i] == list2[j] {
m[i+j] = append(m[i+j], list1[i])
}
}
}
min := len(list1) + len(list2) - 2
for k := range m {
if k < min {
min = k
}
}
return m[min]
}
/**
* 官方解答三,利用哈希表缓存
* 时间 O(l1 + l2)。l1和 l2 是 list1 和 list2的长度,x 是字符串的平均长度。
* 空间 O(l1 *x)
*/
func findRestaurant3(list1 []string, list2 []string) []string {
m := map[string]int{}
for i := 0; i < len(list1); i++ {
m[list1[i]] = i
}
ret := []string{}
min := len(list1) + len(list2) - 2
for j := 0; j < len(list2); j++ {
if k, ok := m[list2[j]]; ok {
if k+j < min {
ret = ret[:0]
ret = append(ret, list2[j])
min = k + j
} else if k+j == min {
ret = append(ret, list2[j])
}
}
}
return ret
}
func main() {
list1 := [][]string{
{"Shogun", "Tapioca Express", "Burger King", "KFC"},
{"Shogun", "Tapioca Express", "Burger King", "KFC"},
{"Shogun", "Tapioca Express", "Burger King", "KFC"},
{"vacag", "KFC"},
{"Shogun", "Piatti", "Tapioca Express", "Burger King", "KFC"},
}
list2 := [][]string{
{"Piatti", "The Grill at Torrey Pines", "Hungry Hunter Steakhouse", "Shogun"},
{"KFC", "Shogun", "Burger King"},
{"KNN", "KFC", "Burger King", "Tapioca Express", "Shogun"},
{"fvo", "xrljq", "jrl", "KFC"},
{"Piatti", "The Grill at Torrey Pines", "Hungry Hunter Steakhouse", "Shogun"},
}
for i := 0; i < len(list1) && i < len(list2); i++ {
fmt.Println("ret:", findRestaurant(list1[i], list2[i]), findRestaurant2(list1[i], list2[i]), findRestaurant3(list1[i], list2[i]))
}
}