golang LeetCode 热题 100(哈希)
两数之和
给定一个整数数组 nums 和一个整数目标值 target,请你在该数组中找出 和为目标值 target 的那 两个 整数,并返回它们的数组下标。
你可以假设每种输入只会对应一个答案,并且你不能使用两次相同的元素。
你可以按任意顺序返回答案。
示例 1:
输入:nums = [2,7,11,15], target = 9
输出:[0,1]
解释:因为 nums[0] + nums[1] == 9 ,返回 [0, 1] 。
示例 2:
输入:nums = [3,2,4], target = 6
输出:[1,2]
示例 3:
输入:nums = [3,3], target = 6
输出:[0,1]
提示:
2 <= nums.length <= 10^4
-10^9 <= nums[i] <= 10^9
-10^9 <= target <= 10^9
只会存在一个有效答案
进阶:你可以想出一个时间复杂度小于 O(n2) 的算法吗?
map
满分解
func twoSum(nums []int, target int) []int {
m:=make(map[int]int,0)
for i:=0;i<len(nums);i++{
if v,ok:=m[target-nums[i]];!ok{
m[nums[i]]=i;
}else{
return []int{v,i}
}
}
return nil
}
官方解
func twoSum(nums []int, target int) []int {
hashTable := map[int]int{}
for i, x := range nums {
if p, ok := hashTable[target-x]; ok {
return []int{p, i}
}
hashTable[x] = i
}
return nil
}
优化
func twoSum(nums []int, target int) []int {
m:=make(map[int]int,0)
for index,value:=range nums{
if v,ok:=m[target-value];!ok{
m[value]=index;
}else{
return []int{v,index}
}
}
return nil
}
原本想着击败更多的人,没想到这个不太准,提交过于频繁被禁掉了,我懂,这是限流。
暴力
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
}
完整代码
package main
import "fmt"
func twoSum(nums []int, target int) []int {
m := make(map[int]int, 0)
for index, value := range nums {
if v, ok := m[target-value]; !ok {
m[value] = index
} else {
return []int{v, index}
}
}
return nil
}
func main() {
fmt.Println("请输入数组长度:")
var n int
var num int
var target int
fmt.Scan(&n)
var arr []int
for i := 0; i < n; i++ {
fmt.Scan(&num)
arr = append(arr, num)
}
fmt.Println("请输入两数之和:")
fmt.Scan(&target)
result := twoSum(arr, target)
fmt.Println(result)
}
字母异位词分组
给你一个字符串数组,请你将 字母异位词 组合在一起。可以按任意顺序返回结果列表。
字母异位词 是由重新排列源单词的所有字母得到的一个新单词。
map
示例 1:
输入: strs = ["eat", "tea", "tan", "ate", "nat", "bat"]
输出: [["bat"],["nat","tan"],["ate","eat","tea"]]
示例 2:
输入: strs = [""]
输出: [[""]]
示例 3:
输入: strs = ["a"]
输出: [["a"]]
提示:
1 <= strs.length <= 104
0 <= strs[i].length <= 100
strs[i] 仅包含小写字母
func groupAnagrams(strs []string) [][]string {
m:=map[string][]string{}
for _,value:=range strs{
s:=[]byte(value)
sort.Slice(s,func(i,j int)bool{return s[i]<s[j]})
sortedStr:=string(s)
m[sortedStr]=append(m[sortedStr],value)
}
ans:=make([][]string,0,len(m))
for _,v:=range m{
ans=append(ans,v)
}
return ans
}
完整代码
package main
import (
"fmt"
"sort"
)
func groupAnagrams(strs []string) [][]string {
mp := make(map[string][]string, 0)
for _, value := range strs {
s := []byte(value)
sort.Slice(s, func(i, j int) bool { return s[i] > s[j] })
sortdStr := string(s)
mp[sortdStr] = append(mp[sortdStr], value)
}
result := make([][]string, 0, len(mp))
for _, value := range mp {
result = append(result, value)
}
return result
}
func main() {
var length int
var str string
strs := []string{}
fmt.Println("请输入长度")
fmt.Scan(&length)
for i := 0; i < length; i++ {
fmt.Scan(&str)
strs = append(strs, str)
}
fmt.Println(groupAnagrams(strs))
}
最长连续序列
给定一个未排序的整数数组 nums ,找出数字连续的最长序列(不要求序列元素在原数组中连续)的长度。
请你设计并实现时间复杂度为 O(n) 的算法解决此问题。
示例 1:
输入:nums = [100,4,200,1,3,2]
输出:4
解释:最长数字连续序列是 [1, 2, 3, 4]。它的长度为 4。
示例 2:
输入:nums = [0,3,7,2,5,8,4,6,0,1]
输出:9
提示:
0 <= nums.length <= 105
-109 <= nums[i] <= 109
暴力(排序)70/77
func longestConsecutive(nums []int) int {
if nums==nil||len(nums)==0{
return 0
}
maxLength:=1
nowLength:=1
for i:=0;i<len(nums);i++{
for j:=i+1;j<len(nums);j++{
if nums[i]>nums[j]{
nums[i],nums[j]=nums[j],nums[i]
}
}
}
for i:=1;i<len(nums);i++{
if nums[i-1]+1==nums[i]{
nowLength++
if nowLength>maxLength{
maxLength=nowLength
}
}else if nums[i-1]!=nums[i] {
nowLength=1
}
}
return maxLength
}
map
简单 70/77
func longestConsecutive(nums []int) int {
mp:=make(map[int]bool,0)
for _,value:=range nums{
mp[value]=true
}
maxLength:=0
for key,_:=range mp{
currentNum:=key
currentLength:=1
for mp[currentNum+1]{
currentLength++
currentNum++
}
if currentLength>maxLength{
maxLength=currentLength
}
}
return maxLength
}
优化
func longestConsecutive(nums []int) int {
mp:=make(map[int]bool,0)
for _,num:=range nums{
mp[num]=true
}
maxLength:=0
for num,_:=range mp{
if !mp[num-1]{
currentNum:=num
currentLength:=1
for mp[currentNum+1]{
currentNum++
currentLength++
}
if maxLength<currentLength{
maxLength=currentLength
}
}
}
return maxLength
}