题目 #
Given an array of integers nums and an integer target, return indices of the two numbers such that they add up to target.
You may assume that each input would have exactly one solution, and you may not use the same element twice.
You can return the answer in any order.
思路1 #
- 暴力遍历,每个数字都向后找自己的另一半
思路2 #
- 每个数字向前找自己的另一半,比上一种遍历少一点
思路3 #
- 在思路2的基础上,找另一半的算法加上优化,使用hashmap进行查找
1func TwoSum(nums []int, target int) []int {
2 hashMap := make(map[int]int)
3 for i, v := range nums {
4 expect := target - v
5 index1, ok := hashMap[expect]
6 if ok {
7 return []int{index1, i}
8 }
9 hashMap[v] = i
10 }
11 return nil
12}