Golang | Leetcode Golang题解之第307题区域和检索-数组可修改

题目:

题解:

Go 复制代码
type NumArray struct {
    nums, tree []int
}

func Constructor(nums []int) NumArray {
    tree := make([]int, len(nums)+1)
    na := NumArray{nums, tree}
    for i, num := range nums {
        na.add(i+1, num)
    }
    return na
}

func (na *NumArray) add(index, val int) {
    for ; index < len(na.tree); index += index & -index {
        na.tree[index] += val
    }
}

func (na *NumArray) prefixSum(index int) (sum int) {
    for ; index > 0; index &= index - 1 {
        sum += na.tree[index]
    }
    return
}

func (na *NumArray) Update(index, val int) {
    na.add(index+1, val-na.nums[index])
    na.nums[index] = val
}

func (na *NumArray) SumRange(left, right int) int {
    return na.prefixSum(right+1) - na.prefixSum(left)
}
相关推荐
过期动态5 小时前
【LeetCode 热题 100】盛最多水的容器
java·数据结构·spring boot·算法·leetcode·spring cloud·职场和发展
凌波粒5 小时前
LeetCode--700.二叉搜索树中的搜索(二叉树)
算法·leetcode·职场和发展
洛水水6 小时前
【力扣100题】58.轮转数组
算法·leetcode
风筝在晴天搁浅6 小时前
阿里 LeetCode 876.链表的中间节点
算法·leetcode·链表
玖釉-6 小时前
二叉树展开为链表:从先序遍历到原地指针重排
c++·windows·算法·leetcode·链表
洛水水7 小时前
【力扣100题】52.最小路径和
算法·leetcode
圣保罗的大教堂7 小时前
leetcode 3043. 最长公共前缀的长度 中等
leetcode
放逐者-保持本心,方可放逐7 小时前
Go + WebAssembly 构建树木数据统计分析系统
开发语言·golang·wasm·javascipt
jieyucx10 小时前
Go 语言 JSON 序列化与反序列化
开发语言·golang·json·序列化
菜菜的顾清寒10 小时前
力扣HOT100(34)图论-岛屿数量
算法·leetcode·图论