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)
}
相关推荐
Tisfy2 小时前
LeetCode 3217.从链表中移除在数组中存在的节点:哈希表(一次遍历)
leetcode·链表·散列表
Tony Bai2 小时前
从 Python 到 Go:我们失去了什么,又得到了什么?
开发语言·后端·python·golang
小白菜又菜2 小时前
Leetcode 495. Teemo Attacking
算法·leetcode·职场和发展
.柒宇.8 小时前
力扣hot100----15.三数之和(java版)
java·数据结构·算法·leetcode
雪域迷影9 小时前
Go语言中通过get请求获取api.open-meteo.com网站的天气数据
开发语言·后端·http·golang·get
程序员阿鹏12 小时前
56.合并区间
java·数据结构·算法·leetcode
数据知道12 小时前
Go语言设计模式:适配器模式详解
设计模式·golang·建造者模式
Brookty15 小时前
【算法】位运算| & ^ ~ -n n-1
学习·算法·leetcode·位运算
剪一朵云爱着15 小时前
力扣2560. 打家劫舍 IV
算法·leetcode