給定一個包含 n
個整數的陣列 nums
,傳回所有唯一的四元組 [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
可以按任何順序返回答案。
Input: nums = [1,0,-1,0,-2,2], target = 0
Output: [[-2,-1,1,2],[-2,0,0,2],[-1,0,0,1]]
Input: nums = [2,2,2,2,2], target = 8
Output: [[2,2,2,2]]
4Sum
是經典的多指針問題,與 Two Sum
和 3Sum
類似。我們的目標是利用排序和雙指針技術來有效地找到所有符合條件的四元組。
主要思路如下:
思路
target
。實現 (Python)
class Solution:
def fourSum(self, nums: List[int], target: int) -> List[List[int]]:
nums.sort() # 對陣列排序
n = len(nums)
result = []
for i in range(n - 3):
# 避免重複的第一個數
if i > 0 and nums[i] == nums[i - 1]:
continue
for j in range(i + 1, n - 2):
# 避免重複的第二個數
if j > i + 1 and nums[j] == nums[j - 1]:
continue
for k in range(j + 1, n - 1):
# 避免重複的第三個數
if k > j + 1 and nums[k] == nums[k - 1]:
continue
for l in range(k + 1, n):
# 避免重複的第四個數
if l > k + 1 and nums[l] == nums[l - 1]:
continue
if nums[i] + nums[j] + nums[k] + nums[l] == target:
result.append([nums[i], nums[j], nums[k], nums[l]])
return result
時間與空間複雜度
思路
nums
進行排序,保證結果有序。實現 (Python)
class Solution:
def fourSum(self, nums: List[int], target: int) -> List[List[int]]:
nums.sort() # 對陣列排序
n = len(nums)
result = []
for i in range(n - 3):
# 避免重複的第一個數
if i > 0 and nums[i] == nums[i - 1]:
continue
for j in range(i + 1, n - 2):
# 避免重複的第二個數
if j > i + 1 and nums[j] == nums[j - 1]:
continue
# 雙指針法處理剩餘的兩個數
left, right = j + 1, n - 1
while left < right:
total = nums[i] + nums[j] + nums[left] + nums[right]
if total == target:
result.append([nums[i], nums[j], nums[left], nums[right]])
# 避免重複的第三個數和第四個數
while left < right and nums[left] == nums[left + 1]:
left += 1
while left < right and nums[right] == nums[right - 1]:
right -= 1
# 繼續移動指針
left += 1
right -= 1
elif total < target:
left += 1 # 和太小,增加左指針
else:
right -= 1 # 和太大,減小右指針
return result
時間與空間複雜度
在實際問題中,雙指針法是更高效的選擇。熟練掌握 Two Sum
、3Sum
、4Sum
等問題的解法,對於處理多指針類問題非常有幫助!