class Solution:
def threeSum(self, nums: List[int]) -> List[List[int]]:
results = []
nums.sort()
for i in range(len(nums) - 2):
#중복된 값 건너뛰기
if i > 0 and nums[i] == nums[i - 1]:
continue
#값을 좁혀가며 합 계산
left, right = i + 1, len(nums) - 1
while left < right:
sum = nums[i] + nums[left] + nums[right]
if sum > 0:
right -= 1
elif sum < 0:
left += 1
else:
results.append([nums[i], 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
return results
'자료구조와 알고리즘' 카테고리의 다른 글
234. Palindrome Linked List(팰린드롬 연결 리스트) (0) | 2023.02.05 |
---|---|
121. Best Time to Buy and Sell Stock(주식을 사고팔기 가장 좋은 시점) (0) | 2023.02.03 |
238. Product of Array Except self(자신을 제외한 배열의 곱) (0) | 2023.02.03 |
561. Array Partition I(배열 파티션 I) (0) | 2023.02.02 |
1. Two Sum(두 수의 합) (0) | 2023.02.02 |