LeetCode-in-Swift

15. 3Sum

Medium

Given an integer array nums, return all the triplets [nums[i], nums[j], nums[k]] such that i != j, i != k, and j != k, and nums[i] + nums[j] + nums[k] == 0.

Notice that the solution set must not contain duplicate triplets.

Example 1:

Input: nums = [-1,0,1,2,-1,-4]

Output: [[-1,-1,2],[-1,0,1]]

Example 2:

Input: nums = []

Output: []

Example 3:

Input: nums = [0]

Output: []

Constraints:

To solve the 3Sum problem in Swift using a Solution class, we’ll follow these steps:

  1. Define a Solution class with a method named threeSum that takes an array of integers nums as input and returns a list of lists representing the triplets that sum up to zero.
  2. Sort the input array nums to ensure that duplicate triplets are avoided.
  3. Initialize an empty list result to store the triplets.
  4. Iterate over the elements of the sorted array nums up to the second to last element.
  5. Within the outer loop, initialize two pointers, left and right, where left starts at the next element after the current element and right starts at the last element of the array.
  6. While left is less than right, check if the sum of the current element (nums[i]), nums[left], and nums[right] equals zero.
  7. If the sum is zero, add [nums[i], nums[left], nums[right]] to the result list.
  8. Move the left pointer to the right (increment left) and the right pointer to the left (decrement right).
  9. If the sum is less than zero, increment left.
  10. If the sum is greater than zero, decrement right.
  11. After the inner loop finishes, increment the outer loop index while skipping duplicates.
  12. Return the result list containing all the valid triplets.

Here’s the implementation:

class Solution {    
    func threeSum(_ nums: [Int]) -> [[Int]] {
        if nums.count < 3 { return [] }
        
        var nums = nums.sorted()
        guard var firstPositiveIndex = nums.firstIndex(where: { $0 >= 0 }) else { return [] }
        
        var result: [[Int]] = []
        var left = 0
        var right = nums.count - 1
        var amount = 0

        for i in (0...firstPositiveIndex) {
            if i > 0 && nums[i] == nums[i-1] { continue }
            
            left = i + 1
            right = nums.count - 1
            
            while left < right {
                
                var amount = nums[i] + nums[left] + nums[right]
                if amount == 0 {
                    if result.last != [nums[i], nums[left], nums[right]] {
                        result.append([nums[i], nums[left], nums[right]])
                    }
                    left += 1
                    right -= 1
                } else if amount > 0 {
                    right -= 1
                } else {
                    left += 1
                }
            }
        }

        return result
    }
}

This implementation provides a solution to the 3Sum problem in Swift.