代码日记:15. 三数之和

解题思路

  • 首先对数组进行排序,这样方便后续双指针夹逼的操作。
  • 对排序后的数组进行遍历,同时使用双指针固定一个数,然后从剩余的部分使用双指针来寻找另外两个数,使它们的和为0。
  • 在固定这个数的循环内,使用双指针分别指向已固定数的右边第一个元素和数组最后一个元素
  • 每次计算三个数的和并比较与0的大小关系,根据大小关系来移动指针,找到所有符合条件的三元组。
// threeSum 函数寻找一个整数数组中所有和为 0 的三元组。
//
// 参数:
// nums: 一个整数数组。
//
// 返回值:
// 返回一个二维整数数组,每个子数组都是一个和为 0 的三元组。
// 如果没有找到满足条件的三元组,则返回空数组。
func threeSum(nums []int) [][]int {
    // 对数组进行排序,以便后续使用双指针法
    sort.Ints(nums)

    // 获取数组长度
    n := len(nums)

    var result [][]int

    // 遍历数组,作为三元组的第一个数字
    for i := 0; i < n-2; i++ {
        // 跳过重复的数字,以避免产生重复的三元组
        if i > 0 && nums[i] == nums[i-1] {
            continue
        }

        left, right := i, n-1
        // 使用双指针法查找剩余两个数字
        for left < right {
            sum := nums[i] + nums[left] + nums[right]
            // 如果找到匹配的三元组,将其添加到结果中,并跳过相同数字
            if sum == 0 {
                result = append(result, []int{nums[i], nums[left], nums[right]})
                for left < right && nums[left] == nums[left+1] {
                    left++
                }
                for left < right && nums[right] == nums[right-1] {
                    right--
                }
            }
            // 如果和大于0,将右指针向左移动
            if sum > 0 {
                right--
            } else { // 如果和小于0,将左指针向右移动
                left++
            }
        }
    }
    return result
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值