mirror of
https://hub.njuu.cf/TheAlgorithms/Python.git
synced 2023-10-11 13:06:12 +08:00
add Three sum (#9177)
* add Three sum * add Three sum * [pre-commit.ci] auto fixes from pre-commit.com hooks for more information, see https://pre-commit.ci * update * update * update * [pre-commit.ci] auto fixes from pre-commit.com hooks for more information, see https://pre-commit.ci * update * [pre-commit.ci] auto fixes from pre-commit.com hooks for more information, see https://pre-commit.ci * add documention --------- Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com>
This commit is contained in:
parent
596d934238
commit
43c3f4ea40
47
maths/three_sum.py
Normal file
47
maths/three_sum.py
Normal file
@ -0,0 +1,47 @@
|
||||
"""
|
||||
https://en.wikipedia.org/wiki/3SUM
|
||||
"""
|
||||
|
||||
|
||||
def three_sum(nums: list[int]) -> list[list[int]]:
|
||||
"""
|
||||
Find all unique triplets in a sorted array of integers that sum up to zero.
|
||||
|
||||
Args:
|
||||
nums: A sorted list of integers.
|
||||
|
||||
Returns:
|
||||
A list of lists containing unique triplets that sum up to zero.
|
||||
|
||||
>>> three_sum([-1, 0, 1, 2, -1, -4])
|
||||
[[-1, -1, 2], [-1, 0, 1]]
|
||||
>>> three_sum([1, 2, 3, 4])
|
||||
[]
|
||||
"""
|
||||
nums.sort()
|
||||
ans = []
|
||||
for i in range(len(nums) - 2):
|
||||
if i == 0 or (nums[i] != nums[i - 1]):
|
||||
low, high, c = i + 1, len(nums) - 1, 0 - nums[i]
|
||||
while low < high:
|
||||
if nums[low] + nums[high] == c:
|
||||
ans.append([nums[i], nums[low], nums[high]])
|
||||
|
||||
while low < high and nums[low] == nums[low + 1]:
|
||||
low += 1
|
||||
while low < high and nums[high] == nums[high - 1]:
|
||||
high -= 1
|
||||
|
||||
low += 1
|
||||
high -= 1
|
||||
elif nums[low] + nums[high] < c:
|
||||
low += 1
|
||||
else:
|
||||
high -= 1
|
||||
return ans
|
||||
|
||||
|
||||
if __name__ == "__main__":
|
||||
import doctest
|
||||
|
||||
doctest.testmod()
|
Loading…
Reference in New Issue
Block a user