(1) 哈希表全思路-20天刷完Leetcode Hot 100计划

计划中一天5+道LeetCode题,因为是第一次写,速度比较慢,但自己会进行纸质笔记整理+CSDN笔记整理,期待20天后熟练掌握!请大家监督我每日更新^^

在Day 1中完成了哈希表3题+滑动窗口2题。

一、哈希表

1. 两数之和

给定nums和target,找到和为target的两个数,返回数组下标

思路

创建一个哈希表,用于在遍历数组时存储已经遍历过的数字与其对应下标。对于新的遍历到的数nums[i],查找target - nums[i]是否已经在哈希表里了:如果在,则找到一组数的和为target;如果还不在,就把新的遍历到的数nums[i]存进哈希表中。

之所以要用哈希表,是因为它

①题目需要返回数组下标,它能同时对应存放下标和数字

②在哈希表中查找,时间复杂度为O(n)

③题目给的是数组,哈希表的enumerate()方法能够直接将数组变为(索引,元素)配对形式

代码

python 复制代码
class Solution(object):
    def twoSum(self, nums, target):
        nums_to_index = {} #创建一个空的哈希表
        for i, num in enumerate(nums):
            complement = target - num
            if complement in nums_to_index:
                return [nums_to_index[complement], i] #hash_table[value] = key
            else:
                nums_to_index[num] = i
        return []

2. 字母异位词分组

给形如["eat", "tea", "tan", "ate", "nat", "bat"]的字符串组,查找出其中哪些是字母异位词,以任意顺序分类返回字母异位词。

思路

首先看到给出的strs格式,它是外包是数组、里面是字符串的形式,我们需要比较的则是字符串中的字符,相当于是三层结构。那么怎么才能得到字符char呢?我们想到sorted()方法 ,是可以将括号中的字符串排序并返回字符列表形式 的;其次,由于需要比较不同顺序的字符串组成,想到:即使是不同顺序的字母异位词,排序后也应该是完全相同的

因此,我们可以考虑用排序后的词作为哈希表的key,用原词序作为value值,遍历strs,最后只需要按不同的key输出value,就可以了!比较不熟的方法有:

①defaultdict 避免了如果key值不在哈希表中,直接拼接会出现错误的场景,如果新建一个哈希表,拿不准的话都可以用hash_table = defaultdict(list)

②sorted() 将字符串排序并返回为字符列表的形式

③' '.join() 将字符列表以' '为连接符,拼接在一起

④hash_table.values() 是哈希表的一种方法,返回字典中所有value的集合,而不返回key;此外,hash_table.keys() 返回所有 key 的集合。hash_table.items返回所有(key, value)键值对的集合。

代码

python 复制代码
from collections import defaultdict

class Solution(object):
    def groupAnagrams(self, strs):
        anagrams = defaultdict(list)
        for s in strs: #对于三层结构中的每一个字符串来说
            key = ''.join(sorted(s)) 
            #把字符串返回为已排序字符,无连接符地拼接到每一个key中
            anagrams[key].append(s)
            #把原字符串s拼接到每一个key对应的value中
        return list(anagrams.values())
        #返回字典里所有的value集合

3. 最长连续序列

给定一个未排序的整数数组nums,找出数字连续的最长序列(不要求序列元素在原数组中连续)的长度。要求时间复杂度为O(n)。

思路

涉及到"找"+O(n),一般就是用哈希表来做了。如果这个题排序的话,时间复杂度肯定超过O(n),所以不能排序。因此把数组变为集合的形式,而集合的底层逻辑就是哈希表,再遍历,找i+1对应的值是否在哈希表中即可。

①set() 方法可以直接将数组转化为哈希表形式

②因为需要长度,所以longest的序列需要被记录起点和终点(2个值)。在遍历过程中,若起点i-1的值也在集合中,则i开头的序列一定比i-1的短

③已知起终点求长度,终点-起点+1

代码

python 复制代码
class Solution(object):
    def longestConsecutive(self, nums):
        nums_set = set(nums) #把数组变为集合形式
        longest = 0
        for i in nums_set:
            if i-1 not in nums_set:
            #如果比i小的也在,那么i一定不是longest的开头
                j = i
                while j+i in num_set:
                    j +=1
                longest = max(longest, j-i+1)
        return longest

3道哈希表就是这样啦!今天还会更一篇滑动窗口。第一天做题感觉还是不容易的,一定不要半途而废呀。希望以后越来越顺畅吧。

相关推荐
冷雨夜中漫步3 小时前
Python快速入门(6)——for/if/while语句
开发语言·经验分享·笔记·python
郝学胜-神的一滴4 小时前
深入解析Python字典的继承关系:从abc模块看设计之美
网络·数据结构·python·程序人生
百锦再4 小时前
Reactive编程入门:Project Reactor 深度指南
前端·javascript·python·react.js·django·前端框架·reactjs
颜酱5 小时前
图结构完全解析:从基础概念到遍历实现
javascript·后端·算法
m0_736919105 小时前
C++代码风格检查工具
开发语言·c++·算法
yugi9878385 小时前
基于MATLAB强化学习的单智能体与多智能体路径规划算法
算法·matlab
喵手5 小时前
Python爬虫实战:旅游数据采集实战 - 携程&去哪儿酒店机票价格监控完整方案(附CSV导出 + SQLite持久化存储)!
爬虫·python·爬虫实战·零基础python爬虫教学·采集结果csv导出·旅游数据采集·携程/去哪儿酒店机票价格监控
2501_944934736 小时前
高职大数据技术专业,CDA和Python认证优先考哪个?
大数据·开发语言·python
helloworldandy6 小时前
使用Pandas进行数据分析:从数据清洗到可视化
jvm·数据库·python
DuHz6 小时前
超宽带脉冲无线电(Ultra Wideband Impulse Radio, UWB)简介
论文阅读·算法·汽车·信息与通信·信号处理