当前位置: 首页 > article >正文

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时,可以直接返回答案。

具体代码如下:

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
}


http://www.kler.cn/a/549611.html

相关文章:

  • 在C++的DLL文件中定义的结构体,在DLL外可以使用吗,如何使用?
  • 兔兔答题应用于微信考试、付费考试、社会调查问卷、明星知识问答、员工培训考核、模拟自测、企业面试、试题库等多种场景。
  • 2D 游戏艺术、动画和光照
  • Oracle序列(基础操作)
  • 排序算法大合集
  • 零基础购买阿里云服务器,XShell连接云服务器
  • 机器学习PCA和LDA
  • Java 设计模式之迭代器模式
  • 升级 SpringBoot3 全项目讲解 — JOOQ 为什么全面超越了 Mybatis?
  • vueRouter(路由)
  • MongoDB:记一次数据迁移经验
  • Qt——连接MySQL数据库之ODBC的方法详细总结(各版本大同小异,看这一篇就够了)
  • Qt使用CipherSqlite插件访问加密的sqllite数据库
  • (二)Axure 9 制作计时器
  • 【MySQL】高频 SQL 50 题(基础版)
  • trl+DPO 算法
  • 2010年上半年软件设计师考试上午真题的知识点整理(附真题及答案解析)
  • 腿足机器人之四- 卡尔曼滤波
  • Redis c++安装使用教程(redis-plus-plus)
  • 红队视角出发的k8s敏感信息收集——Kubernetes API 扩展与未授权访问