LeetCode--15. 三数之和

15. 三数之和

给你一个整数数组 nums ,判断是否存在三元组 [nums[i], nums[j], nums[k]] 满足 i != ji != kj != k ,同时还满足 nums[i] + nums[j] + nums[k] == 0 。请你返回所有和为 0 且不重复的三元组。

**注意:**答案中不可以包含重复的三元组。


正文

三数之和,总体思路是排序+双指针,相较于暴力的O(n^3)优化了不少,遍历过程中也可以适当的剪枝来进一步优化,

具体思路如下:

  1. 先排序,将数组变成有序的,数组长度为n
  2. 随后第一层遍历元素i
  3. 定义双指针:j,k以及目标值target,其中,j的初始值为i + 1, k的初始值为n - 1, target为-nums[i].
  4. 循环遍历j,循环内嵌k,当nums[k] + nums[j] > target时,k--,最后如果找不到相应的target,则进行continue,若找到了,则加入答案中。
  5. 在遍历过程中,如果nums[i] > 0时,可以直接返回答案。

具体代码如下:

go 复制代码
func threeSum(nums []int) [][]int {
    n := len(nums)
    sort.Ints(nums)
    ans := make([][]int, 0)
    for i := 0; i < n; i ++ {
        if nums[i] > 0 {
            return ans
        }
        if i > 0 && nums[i] == nums[i - 1] {
            continue
        }

        k := n - 1
        target := -nums[i]

        for j := i + 1; j < n; j ++ {
            if j > i + 1 && nums[j] == nums[j - 1] {
                continue
            }
            for j < k && nums[j] + nums[k] > target {
                k --
            }

            if j == k {
                break
            } else if target == nums[k] + nums[j] {
                ans = append(ans, []int{nums[i], nums[j], nums[k]})
            }
        }
    }
    return ans
}

相关推荐
墨染点香10 小时前
LeetCode 刷题【146. LRU 缓存】
leetcode·缓存·哈希算法
快手技术10 小时前
从“拦路虎”到“修路工”:基于AhaEdit的广告素材修复
前端·算法·架构
qk学算法10 小时前
力扣滑动窗口题目-76最小覆盖子串&&1234替换子串得到平衡字符串
数据结构·算法·leetcode
小欣加油10 小时前
leetcode 860 柠檬水找零
c++·算法·leetcode·职场和发展·贪心算法
还是码字踏实11 小时前
基础数据结构之数组的矩阵遍历:螺旋矩阵(LeetCode 54 中等题)
数据结构·leetcode·矩阵·螺旋矩阵
粉色挖掘机11 小时前
矩阵在密码学的应用——希尔密码详解
线性代数·算法·机器学习·密码学
周杰伦_Jay12 小时前
【主流开发语言深度对比】Python/Go/Java/JS/Rust/C++评测
开发语言·python·golang
七七七七0712 小时前
【计算机网络】UDP协议深度解析:从报文结构到可靠性设计
服务器·网络·网络协议·计算机网络·算法·udp
ldmd28412 小时前
Go语言实战:入门篇-5:函数、服务接口和Swagger UI
开发语言·后端·golang
TitosZhang12 小时前
排序算法稳定性判断
数据结构·算法·排序算法