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)
}
相关推荐
玛丽莲茼蒿6 小时前
Leetcode hot100 每日温度【中等】
算法·leetcode·职场和发展
样例过了就是过了6 小时前
LeetCode热题100 分割等和子集
数据结构·c++·算法·leetcode·动态规划
北顾笙9806 小时前
day38-数据结构力扣
数据结构·算法·leetcode
m0_629494736 小时前
LeetCode 热题 100-----14.合并区间
数据结构·算法·leetcode
xin_nai7 小时前
LeetCode热题100(Java)(5)普通数组
算法·leetcode·职场和发展
水蓝烟雨9 小时前
3337. 字符串转换后的长度 II
算法·leetcode
_日拱一卒9 小时前
LeetCode:226翻转二叉树
数据结构·算法·leetcode
踩坑记录9 小时前
leetcode hot100 64. 最小路径和 medium 递归优化
leetcode·深度优先
lolo大魔王9 小时前
Go语言的并发、协调创建和通信机制
开发语言·golang
样例过了就是过了10 小时前
LeetCode热题100 最长有效括号
c++·算法·leetcode·动态规划