代码随想录算法训练营第七天| 454.四数相加II 、 383. 赎金信、15. 三数之和 、18. 四数之和

454. 四数相加 II

首先想到的是最暴力的解法:嵌套四个for循环遍历得到满足条件的元组,使用计数器统计。

 当然肯定会超时。

然后试着尝试使用字典来解决问题,但是发现如果使用数组下标来储存的话依然不行,因为数组数量太多数据量太大了, 遂看视频学习 

学透哈希表,map使用有技巧!LeetCode:454.四数相加II_哔哩哔哩_bilibili

看完以后收获颇丰,尽管细节上需要注意的点有点多,但是还是看完视频还是能自己做完了,核心思想就是把四个数组拆成两组来解决,确保时间复杂度从O(n4)降为 O(n2)

这里我直接使用代码随想录给出的步骤,非常的清晰:

代码随想录

  1. 首先定义 一个unordered_map,key放a和b两数之和,value 放a和b两数之和出现的次数。
  2. 遍历大A和大B数组,统计两个数组元素之和,和出现的次数,放到map中。
  3. 定义int变量count,用来统计 a+b+c+d = 0 出现的次数。
  4. 在遍历大C和大D数组,找到如果 0-(c+d) 在map中出现过的话,就用count把map中key对应的value也就是出现次数统计出来。
  5. 最后返回统计值 count 就可以了

 

 

383. 赎金信 

给你两个字符串:ransomNote 和 magazine ,判断 ransomNote 能不能由 magazine 里面的字符构成。

如果可以,返回 true ;否则返回 false 。

magazine 中的每个字符只能在 ransomNote 中使用一次。

被四数之和折磨完后做这个题就比较轻松,使用哈希表统计即可。

 

15. 三数之和

给你一个整数数组 nums ,判断是否存在三元组 [nums[i], nums[j], nums[k]] 满足 i != ji != k 且 j != k ,同时还满足 nums[i] + nums[j] + nums[k] == 0 。请

你返回所有和为 0 且不重复的三元组。

注意:答案中不可以包含重复的三元组。

拿到这道题首先我想使用暴力解法试试看,然后发现如果无脑使用三层循环会出现元组重复的问题, 使用哈希表的时候我也发现了这个问题,尝试了发现找不到一个有效的方法来去重,于是去看视频学习。

梦破碎的地方!| LeetCode:15.三数之和_哔哩哔哩_bilibili

原来这题看上去是使用哈希表,但实际上使用哈希表会出现非常多的问题,使用双指针才是正确的,去重一直也是我的弱项,这道题应该好好研究。

使用完双指针法遍历后,提交发现依然有重复的元素,因为我没有降重,由于使用双指针前已经给数组排好序了,那么我们降重就好办了。

其他的细节都在代码随想录的视频中,感觉这题真的还是有点难度的,注意是细节把控不好就会出现降重错误。 

 

18. 四数之和

给你一个由 n 个整数组成的数组 nums ,和一个目标值 target 。请你找出并返回满足下述全部条件且不重复的四元组 [nums[a], nums[b], nums[c], nums[d]] (若两个四元组元素一一对应,则认为两个四元组重复):

  • 0 <= a, b, c, d < n
  • abc 和 d 互不相同
  • nums[a] + nums[b] + nums[c] + nums[d] == target

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

 难在去重和剪枝!| LeetCode:18. 四数之和_哔哩哔哩_bilibili

三数之和升级版,看完视频认识到三数之和就是一个循环两个指针,四数之和就是两个循环两个指针,然后就是去重,细节很多,今天这两道题可以说是很烧脑了。

 

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值