当前位置: 首页 > article >正文

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
}

http://www.kler.cn/a/452171.html

相关文章:

  • MySQL变量
  • 人工智能ACA(七)——计算机视觉基础
  • dockerfile文档编写(1):基础命令
  • 43. Three.js案例-绘制100个立方体
  • 大语言模型中的Agent;常见的Agent开发工具或框架
  • MySQL最左匹配原则是什么
  • 【zookeeper核心源码解析】第二课:俯瞰QuorumPeer启动核心流程,实现选举关键流程
  • UI自动化测试实战实例
  • debian 编译openwrt
  • idea集合git使用
  • 单片机:实现LED亮度等级控制(附带源码)
  • Zookeeper常见面试题解析
  • Docker 快速搭建 GBase 8s数据库服务
  • 重温设计模式--6、享元模式
  • Android蓝牙通信
  • VR 动感单车身心调适系统的功能与作用
  • 前端 MYTED单篇TED词汇学习功能优化
  • Leetcode 695 Max Area of Island
  • Logback日志框架中的继承机制详解
  • 学习postman工具使用
  • 头歌-机器学习在 NLP 中的实战
  • Github 2024-12-25C开源项目日报 Top8
  • HTTP 协议、AJAX - 异步网络请求及跨域、同源策略
  • LabVIEW软件项目设计方案如何制定
  • 构建专属AI知识库:Obsidian Copilot + 硅基流动SiliconCloud API 实战指南
  • 汽车消费新旺季到来,联众优车年末冲刺把好服务关