Golang | Leetcode Golang题解之第525题连续数组

题目:

题解:

Go 复制代码
func findMaxLength(nums []int) (maxLength int) {
    mp := map[int]int{0: -1}
    counter := 0
    for i, num := range nums {
        if num == 1 {
            counter++
        } else {
            counter--
        }
        if prevIndex, has := mp[counter]; has {
            maxLength = max(maxLength, i-prevIndex)
        } else {
            mp[counter] = i
        }
    }
    return
}

func max(a, b int) int {
    if a > b {
        return a
    }
    return b
}
相关推荐
阿Y加油吧1 天前
算法实战笔记:LeetCode 169 多数元素 & 75 颜色分类
笔记·算法·leetcode
不要秃头的小孩1 天前
力扣刷题——509. 斐波那契数
python·算法·leetcode·动态规划
U盘失踪了1 天前
Go 结构体
笔记·golang
We་ct1 天前
LeetCode 120. 三角形最小路径和:动态规划详解
前端·javascript·算法·leetcode·typescript·动态规划
py有趣1 天前
力扣热门100题之和为K的子数组
数据结构·算法·leetcode
py有趣1 天前
力扣热门100题之编辑距离
数据结构·算法·leetcode
水木流年追梦1 天前
CodeTop 热门题目汇总hot300题
算法·leetcode·职场和发展
f3iiish1 天前
2078. 两栋颜色不同且距离最远的房子 力扣
算法·leetcode
sheeta19981 天前
LeetCode 每日一题笔记 日期:2026.04.21 题目:1722. 执行交换操作后的最小汉明距离
笔记·算法·leetcode
贺小涛1 天前
python和golang进程、线程、协程区别
java·python·golang