当前位置: 首页 > news >正文

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

题目:

题解:

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)
}
http://www.lryc.cn/news/412011.html

相关文章:

  • Golang | Leetcode Golang题解之第301题删除无效的括号
  • 【Story】《程序员面试的“八股文”辩论:技术基础与实际能力的博弈》
  • 初步了解泛型
  • 【C#】.net core 6.0 webapi 使用core版本的NPOI的Excel读取数据以及保存数据
  • C++推荐的oj网站
  • springmvc处理http请求的底层逻辑
  • 干货满满,从零到一:编程小白如何在大学成为编程大神?
  • 前端-如何通过docker打包Vue服务成镜像并在本地运行(本地可以通过http://localhost:8080/访问前端服务)
  • 零基础学习【Mybatis】这一篇就够了
  • Shell入门(保姆级教学)
  • 【JDK11和JDK8并行与切换】
  • vue大数据量列表渲染性能优化:虚拟滚动原理
  • 昇思25天学习打卡营第1天|快速入门
  • LinkedList 实现 LRU 缓存
  • ubuntu安装workon
  • (面试必看!)锁策略
  • RAGflow:开源AI框架的创新与应用
  • AI的学习明确路径
  • 【C++】巧用缺省参数与函数重载:提升编程效率的秘密武器
  • mysql排查死锁的几个查询sql
  • 快速部署私有化大模型 毕昇(使用docker-compose方式)
  • B端:导航条就框架提供的默认样式吗?非也,看过来。
  • idea的git与SVN切换
  • 互联网家政小程序,为大众带来高效、便捷的服务
  • 【常用库】【pytorch】基本部件
  • 深入Scrapy框架:掌握其工作流程
  • 从零开始学习机器学习,掌握AI未来的关键!
  • CI/CD(持续集成/持续部署)
  • 实现字母的大小写转换。多组输入输出(c语言)
  • 2024华为OD机试真题-最小矩阵宽度Python-C卷D卷-200分