【LeetCode】1. 兩數之和(gloang)

第一個種解法 暴力判斷 耗時較久

package main

import "fmt"

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

func twoSum(nums []int, target int) []int {
	length := len(nums)
	for i := 0; i < length; i++ {
		for j := i + 1; j < length; j++ {
			if nums[i]+nums[j] == target {
				return []int{i, j}
			}
		}
	}
	return []int{}
}

第二種解法 哈希 用時較少

package main

import "fmt"

func main() {
	results := twoSum([]int{3, 2, 4}, 6)
	fmt.Println(results)
}

func twoSum(nums []int, target int) []int {
	cache := map[int]int{}
	for key, value := range nums {
		cache[value] = key
	}
	length := len(nums)
	for i := 0; i < length; i++ {
		value := target - nums[i]
		key, ok := cache[value]
		if ok == true && key != i {
			return []int{i, key}
		}
	}
	return []int{}
}
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章