《LeetCode 热题 100》

《LeetCode 热题 100》持续更新

一、hash表

1.两数之和

【题解】遍历nums数组,判断target-num是否在hash表中,如果不在就把当前遍历的数字和其下表加入到hash表中,如果在则返回hash表中数字的下标以及当前数字下标。

当然也可以使用暴力求解,第二层遍历看target-num是否在数组nums中。

【代码】

python 复制代码
class Solution(object):
    def twoSum(self, nums, target):
        """
        :type nums: List[int]
        :type target: int
        :rtype: List[int]
        """
        hashmap=dict()
        for i,num in enumerate(nums):
            if target-num in hashmap:
                return [hashmap[target-num],i]
            hashmap[nums[i]]=i

49.字母异位词分组

【题解】对字符串数组中每个单词进行排序,使得其按正序排序。接着遍历排序过的字符串数组,并把排列相同的单词放入到hash表中,key为字母排序,值为字符串数组中的单词。

【代码】

python 复制代码
strs = ["eat", "tea", "tan", "ate", "nat", "bat"]
res = dict()
sortedStrs = [''.join(sorted(list(s))) for s in strs]
for i in range(len(sortedStrs)):
    if sortedStrs[i] not in res.keys():
        res[sortedStrs[i]] = [strs[i]]
    else:
        res[sortedStrs[i]].append(strs[i])
print( list(res.values()))

128.最长连续序列

【题解】用一个set存储list,然后遍历这个set,看当前数的前一个数在不在set中,如果在就下一个,如果不在一直循环直到下一个数不在。为什么要查看当前数的前一个数在不在,是因为避免重复循环,就是要找到第一个循环的数(即最小的数)。

python 复制代码
class Solution:
    def longestConsecutive(self, nums: List[int]) -> int:
        max_len=0
        num_set =set(nums)
        for num in num_set:
            if (num-1) not in num_set:
                seq_len=1
                while (num+1) in num_set:
                    seq_len+=1
                    num+=1
                max_len = max(max_len,seq_len)
        
        return max_len
相关推荐
ArturiaZ13 分钟前
【day55】
数据结构·c++·算法
仰泳的熊猫16 分钟前
题目2279:蓝桥杯2018年第九届真题-日志统计
数据结构·c++·算法·蓝桥杯
一叶落43816 分钟前
LeetCode 11:盛最多水的容器(C语言实现)
c语言·数据结构·算法·leetcode
Emilin Amy19 分钟前
一台具备了“观察力”的下肢康复外骨骼机器人
算法·机器人
I_LPL19 分钟前
day53 代码随想录算法训练营 图论专题7
算法·图论
_日拱一卒20 分钟前
LeetCode(力扣):二叉树的后序遍历
算法·leetcode·职场和发展
Emilin Amy23 分钟前
【ROS】机器人的速度/角度/力矩控制是如何实现的
c++·算法·控制·ros1/2
sali-tec26 分钟前
C# 基于OpenCv的视觉工作流-章36-骨架提取
图像处理·人工智能·opencv·算法·计算机视觉
CoovallyAIHub28 分钟前
RF-DETR:最近一个月迭代 5 个版本的实时检测+分割模型
深度学习·算法·计算机视觉
Frostnova丶28 分钟前
LeetCode 1878. 矩阵中最大的三个菱形和
算法·leetcode·矩阵