LeetCode题解(Golang实现)--Two Sum
发布时间:2020-12-16 18:06:52 所属栏目:大数据 来源:网络整理
导读:题目 Given an array of integers,return indices of the two numbers such that they add up to a specific target. You may assume that each input would have exactly one solution,and you may not use the same element twice. Example:Given nums = [
题目Given an array of integers,return indices of the two numbers such that they add up to a specific target. You may assume that each input would have exactly one solution,and you may not use the same element twice. Example:
Given nums = [2,7,11,15],target = 9,Because nums[0] + nums[1] = 2 + 7 = 9,return [0,1].
思路有三种解题思路,但是我只谢了两种 答案
func twoSum(nums []int,target int) []int {
for i:=0;i<len(nums);i++{
for j:=i+1;j<len(nums);j++{
if nums[i]+nums[j] == target {
return []int{i,j}
}
}
}
return nil
}
//时间复杂度为o(n^2)
2. func twoSum(nums []int,target int) []int {
maps := map[int]int{}
for index,value := range nums {
member := target - value
if key,ok := maps[member];ok{
return []int{key,index}
}else{
maps[value] = index
}
}
return nil
}
//时间复杂度为o(n) (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |