数状数组模板(板子该记还得记)

阅读: 评论:0

数状数组模板(板子该记还得记)

数状数组模板(板子该记还得记)



树状数组模板

// 上来先把三个方法写出来
{int[] tree;int lowbit(int x) {return x & -x;}// 查询前缀和的方法int query(int x) {int ans = 0;for (int i = x; i > 0; i -= lowbit(i)) ans += tree[i];return ans;}// 在树状数组 x 位置中增加值 uvoid add(int x, int u) {for (int i = x; i <= n; i += lowbit(i)) tree[i] += u;}
}// 初始化「树状数组」,要默认数组是从 1 开始
{for (int i = 0; i < n; i++) add(i + 1, nums[i]);
}// 使用「树状数组」:
{   void update(int i, int val) {// 原有的值是 nums[i],要使得修改为 val,需要增加 val - nums[i]add(i + 1, val - nums[i]); nums[i] = val;}int sumRange(int l, int r) {return query(r + 1) - query(l);}
}

本题解题代码

class NumArray {int tree[];int nums[];int n;public int lowBit(int x){return x&-x;}public void add(int x,int val){for(int i=x;i<=n;i+=lowBit(i))tree[i]+=val;}public int query(int x){int ans=0;for(int i=x;i>0;i-=lowBit(i))ans+=tree[i];return ans;}public NumArray(int[] _nums) {nums=_nums;n=nums.length;tree=new int[n+1];for(int i=0;i<nums.length;i++){add(i+1,nums[i]);}}public void update(int index, int val) {add(index+1,val-nums[index]);nums[index]=val;}public int sumRange(int left, int right) {return query(right+1)-query(left);}
}

本文发布于:2024-02-02 23:51:22,感谢您对本站的认可!

本文链接:https://www.4u4v.net/it/170688908147284.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

上一篇:今天必须得记
标签:板子   还得   数组   模板
留言与评论(共有 0 条评论)
   
验证码:

Copyright ©2019-2022 Comsenz Inc.Powered by ©

网站地图1 网站地图2 网站地图3 网站地图4 网站地图5 网站地图6 网站地图7 网站地图8 网站地图9 网站地图10 网站地图11 网站地图12 网站地图13 网站地图14 网站地图15 网站地图16 网站地图17 网站地图18 网站地图19 网站地图20 网站地图21 网站地图22/a> 网站地图23