首先想到的是最暴力的解法:嵌套四个for循环遍历得到满足条件的元组,使用计数器统计。
当然肯定会超时。
然后试着尝试使用字典来解决问题,但是发现如果使用数组下标来储存的话依然不行,因为数组数量太多数据量太大了, 遂看视频学习
学透哈希表,map使用有技巧!LeetCode:454.四数相加II_哔哩哔哩_bilibili
看完以后收获颇丰,尽管细节上需要注意的点有点多,但是还是看完视频还是能自己做完了,核心思想就是把四个数组拆成两组来解决,确保时间复杂度从O(n4)降为 O(n2)
这里我直接使用代码随想录给出的步骤,非常的清晰:
- 首先定义 一个unordered_map,key放a和b两数之和,value 放a和b两数之和出现的次数。
- 遍历大A和大B数组,统计两个数组元素之和,和出现的次数,放到map中。
- 定义int变量count,用来统计 a+b+c+d = 0 出现的次数。
- 在遍历大C和大D数组,找到如果 0-(c+d) 在map中出现过的话,就用count把map中key对应的value也就是出现次数统计出来。
- 最后返回统计值 count 就可以了
给你两个字符串:ransomNote
和 magazine
,判断 ransomNote
能不能由 magazine
里面的字符构成。
如果可以,返回 true
;否则返回 false
。
magazine
中的每个字符只能在 ransomNote
中使用一次。
被四数之和折磨完后做这个题就比较轻松,使用哈希表统计即可。
给你一个整数数组 nums
,判断是否存在三元组 [nums[i], nums[j], nums[k]]
满足 i != j
、i != k
且 j != k
,同时还满足 nums[i] + nums[j] + nums[k] == 0
。请
你返回所有和为 0
且不重复的三元组。
注意:答案中不可以包含重复的三元组。
拿到这道题首先我想使用暴力解法试试看,然后发现如果无脑使用三层循环会出现元组重复的问题, 使用哈希表的时候我也发现了这个问题,尝试了发现找不到一个有效的方法来去重,于是去看视频学习。
梦破碎的地方!| LeetCode:15.三数之和_哔哩哔哩_bilibili
原来这题看上去是使用哈希表,但实际上使用哈希表会出现非常多的问题,使用双指针才是正确的,去重一直也是我的弱项,这道题应该好好研究。
使用完双指针法遍历后,提交发现依然有重复的元素,因为我没有降重,由于使用双指针前已经给数组排好序了,那么我们降重就好办了。
其他的细节都在代码随想录的视频中,感觉这题真的还是有点难度的,注意是细节把控不好就会出现降重错误。
给你一个由 n
个整数组成的数组 nums
,和一个目标值 target
。请你找出并返回满足下述全部条件且不重复的四元组 [nums[a], nums[b], nums[c], nums[d]]
(若两个四元组元素一一对应,则认为两个四元组重复):
0 <= a, b, c, d < n
a
、b
、c
和d
互不相同nums[a] + nums[b] + nums[c] + nums[d] == target
你可以按 任意顺序 返回答案 。
难在去重和剪枝!| LeetCode:18. 四数之和_哔哩哔哩_bilibili
三数之和升级版,看完视频认识到三数之和就是一个循环两个指针,四数之和就是两个循环两个指针,然后就是去重,细节很多,今天这两道题可以说是很烧脑了。