<span>树状数组模版</span>

int lowbit(int x)
{
    return x&(-x);
}
修改某个位置上的值,查找一段区间的和(向上修改,向下统计)
void update(int x,int num)
{
    while(x<=MAXN)
     {
         c[x]+=num;
         x+=lowbit(x);
     }
}
int getSum(int x)
{
    int s=0;
    while(x>0)
     {
         s+=c[x];
         x-=lowbit(x);
     }
    return s;
}
修改一段区间的值,查找某个位上的值(向上统计,向下修改)
void update(int x,int num)
{
    while(x>0)
     {
         c[x]+=num;
         x-=lowbit(x);
     }
}
int getSum(int x)
{
    int s=0;
    while(x<=MAXN)
     {
         s+=c[x];
         x+=lowbit(x);
     }
    return s;
}

 

全部评论

相关推荐

不愿透露姓名的神秘牛友
10-12 10:48
已编辑
秋招之苟:邻居家老哥19届双2硕大厂开发offer拿遍了,前几天向他请教秋招,他给我看他当年的简历,0实习实验室项目技术栈跟开发基本不沾边😂,我跟他说这个放在现在中厂简历都过不了
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务