1. 两数之和

给定一个整数数组 nums 和一个目标值 target,请你在该数组中找出和为目标值的那 两个 整数,并返回他们的数组下标。

你可以假设每种输入只会对应一个答案。但是,你不能重复利用这个数组中同样的元素。

示例:

给定 nums = [2, 7, 11, 15], target = 9

因为 nums[0] + nums[1] = 2 + 7 = 9
所以返回 [0, 1]

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/two-sum
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

package main

import (
	"fmt"
)

func twoSum(nums []int, target int) []int {
	tmp := make(map[int]int)
	res := make([]int, 2)

	for k, v := range nums {
		tmp[v] = k
	}

	for k, v := range nums {
		res[0] = k
		value := target - v
		index, ok := tmp[value]
		if ok && index != k {
			res[1] = index
			break
		}
	}

	return res
}

func main() {
	var nums = []int{2,7,11,15}
	var ha []int
	ha = twoSum(nums, 9)
	fmt.Println(ha)

}

  

posted @ 2019-07-29 15:36  fangjianyi  阅读(81)  评论(1编辑  收藏  举报