Golang | Leetcode Golang题解之第220题存在重复元素III

题目:

题解:

Go 复制代码
func getID(x, w int) int {
    if x >= 0 {
        return x / w
    }
    return (x+1)/w - 1
}

func containsNearbyAlmostDuplicate(nums []int, k, t int) bool {
    mp := map[int]int{}
    for i, x := range nums {
        id := getID(x, t+1)
        if _, has := mp[id]; has {
            return true
        }
        if y, has := mp[id-1]; has && abs(x-y) <= t {
            return true
        }
        if y, has := mp[id+1]; has && abs(x-y) <= t {
            return true
        }
        mp[id] = x
        if i >= k {
            delete(mp, getID(nums[i-k], t+1))
        }
    }
    return false
}

func abs(x int) int {
    if x < 0 {
        return -x
    }
    return x
}
相关推荐
我搞slam7 分钟前
快乐数--leetcode
算法·leetcode·哈希算法
西阳未落2 小时前
LeetCode——二分(进阶)
算法·leetcode·职场和发展
小羊在睡觉3 小时前
golang定时器
开发语言·后端·golang
不爱洗脚的小滕4 小时前
【Redis】三种缓存问题(穿透、击穿、双删)的 Golang 实践
redis·缓存·golang
吃着火锅x唱着歌4 小时前
LeetCode 410.分割数组的最大值
数据结构·算法·leetcode
YSRM5 小时前
Leetcode+Java+图论+最小生成树&拓扑排序
java·leetcode·图论
YSRM5 小时前
Leetcode+Java+图论+并查集
算法·leetcode·图论
小白杨树树5 小时前
【C++】力扣hot100错误总结
c++·leetcode·c#
吃着火锅x唱着歌8 小时前
LeetCode 668.乘法表中第k小的数
算法·leetcode·职场和发展