LeetCode hot100部分题目算法总结(自用)

哈希(hash)相关

1.两数之和 链接

T:给定一个整数数组 n u m s nums nums 和一个整数目标值 t a r g e t target target,请你在该数组中找出和为目标值 t a r g e t target target 的那 两个整数,并返回它们的数组下标。

你可以假设每种输入只会对应一个答案。但是,数组中同一个元素在答案里不能重复出现。

你可以按任意顺序返回答案。

A:暴力算法/hash。hash:python用字典就行了。查字典里面是否有 t a r g e t − x target-x targetx即可。
ps:可恶啊,今天面试考这题,我忘了个干干净净,都是没动手写一般代码的锅。

49.字母异位词分组

T:给你一个字符串数组,请你将 字母异位词 组合在一起。可以按任意顺序返回结果列表。

字母异位词 是由重新排列源单词的所有字母得到的一个新单词。
在这里插入图片描述
T: hash不太行,排序可以,每个单词先排序,再对strs排序。

ans1 = sorted(strs,key=lambda x:''.join(sorted(x)))

128.最长连续序列

T:

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

请你设计并实现时间复杂度为 O(n) 的算法解决此问题。

A:hash去重,再一个个数,复杂度是 O ( n l o g ( n ) ) O(nlog(n)) O(nlog(n))

双指针

283 移动零 链接

T:给定一个数组 nums,编写一个函数将所有 0 移动到数组的末尾,同时保持非零元素的相对顺序。

请注意 ,必须在不复制数组的情况下原地对数组进行操作。

A:双指针就可以解决。

11 盛最多水的容器 链接

典型双指针,left right 从两边夹逼,并记录最大面积就行。

15 三数之和

链接
最简单的算法是排序、固定一个数、双指针夹逼。
需要注意几个点:

  • 固定数 num[i]的时候,是从左往右固定,而left和right的初始值是i+1和len(num)-1。
  • 当num[i]>0,返回ans
  • 当nums[i] + nums[j] + nums[l]==0时,
while (i<j and nums[i]==nums[i+1]):
                        i+=1
while (i<j and nums[j-1]==nums[j]):
                        j-=1
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值