【力扣打卡系列】滑动窗口与双指针(三数之和)

坚持按题型打卡&刷&梳理力扣算法题系列,语言为go,Day2

三数之和
  • 题目描述
  • 解题思路
    • 先有序化数组
    • 因为有三个数,所以i遍历到倒数第三个数就好
    • 注意去重操作(i,j,k都需要)
    • 在i的循环中进行j和k的循环(即固定一个i的情况下转换为双指针问题)
    • 注意两个可以优化的点
    • 什么时候直接break;什么时候可以continue
  • 代码参考
go 复制代码
func threeSum(nums []int) (ans [][]int) {
    //先有序化数组
    slices.Sort(nums)
    for i := range nums[:len(nums)-2]{
        //去重
        if i > 0 && nums[i] == nums[i-1]{
            continue
        }
        if nums[i] + nums[i + 1] + nums[i + 2] > 0{
            break
        }
        if nums[i] + nums[len(nums)-2] + nums[len(nums)-1] < 0{
            continue
        }
        j,k := i+1, len(nums)-1
        for j < k{
            if nums[i] + nums[j] + nums[k] == 0{
                ans = append(ans,[]int{nums[i],nums[j],nums[k]})
                //比较相等时,也需要同时移动j和k指针来找下一组,此时注意j和k也需要去重操作
                for j++; j<k && nums[j]==nums[j-1];j++{}
                for k--; k>j && nums[k]==nums[k+1];k--{}
            }
            if nums[i] + nums[j] + nums[k] < 0{
                j++
            }
            if nums[i] + nums[j] + nums[k] > 0{
                k--
            }
        }
    }
    return ans
}
  • tips
    • 数组排序:slices.Sort(nums)(注意slices是第一个字母小写,Sort第一个字母大写)
    • 二维数组添加一维数组元素
      • ans [][]int // 用append添加 ans = append(ans, []int{x, nums[j], nums[k]})
    • 数组循环用切片限定循环次数
      • //注意是前包含后不包含 for i:=range nums[:n-2]{}
    • go最后需要有返回值,例如return nil
    • 注意必须有j < k这个限定条件
    • 在 Go 语言中,分号 ;for 循环中起到分隔循环的各个部分的作用,它将初始化语句、条件判断、和更新语句 分隔开
      • j, k := i+1, n-1 //注意:上述语句应该写在循环体里面,因为每更新一个i都需要重置
    • 注意:双指针的移动也是一个循环的过程
相关推荐
K8sCat22 分钟前
Golang与Kafka的五大核心设计模式
后端·kafka·go
BB_CC_DD27 分钟前
四. 以Annoy算法建树的方式聚类清洗图像数据集,一次建树,无限次聚类搜索,提升聚类搜索效率。(附完整代码)
深度学习·算法·聚类
孔令飞1 小时前
Go:终于有了处理未定义字段的实用方案
人工智能·云原生·go
唐僧洗头爱飘柔95272 小时前
(Go Gin)上手Go Gin 基于Go语言开发的Web框架,本文介绍了各种路由的配置信息;包含各场景下请求参数的基本传入接收
后端·golang·go·restful·gin·goweb开发
梁下轻语的秋缘2 小时前
每日c/c++题 备战蓝桥杯 ([洛谷 P1226] 快速幂求模题解)
c++·算法·蓝桥杯
CODE_RabbitV2 小时前
【深度强化学习 DRL 快速实践】逆向强化学习算法 (IRL)
算法
mit6.8242 小时前
[贪心_7] 最优除法 | 跳跃游戏 II | 加油站
数据结构·算法·leetcode
keep intensify3 小时前
通讯录完善版本(详细讲解+源码)
c语言·开发语言·数据结构·算法
shix .3 小时前
2025年PTA天梯赛正式赛 | 算法竞赛,题目详解
数据结构·算法
风铃儿~3 小时前
Java面试高频问题(26-28)
java·算法·面试