[蓝桥杯学习] 树状树组

lowbit操作

数字二进制表达中的最低位1以及后面所有的0,函数写法如下:

cpp 复制代码
int lowbit(int x){return x&-x;}

例如说,lowbit(0101100100) = (100)

lowbit(4) = 4 lowbit(6) = 2

时间复杂度o(1)

树状数组

应用

进行单点修改和区间查询,时间复杂度为O(logn)

结构

进行单点修改

修改t[i],然后 i=i+lowbit(i) ,修改t[i]

进行区间查询

查询区间和,就拆分成求前缀和,求(a,b),就拆成(1,b)-(1,a-1)

i=i-lowbit(i)

修改和查询函数的代码

注意,一定是 >0

例题

愉悦值的计算就是求区间和

有两个操作,修改和查询,使用树状数组的数据结构。

cpp 复制代码
#include <iostream>
using namespace std;

const int N = 1e7;
using ll = long long;
ll a[N],t[N];
int n;

int lowbit(int x) {return x&-x;}

void update(int k,ll x)
{
  a[k] += x;
  for(int i = k ; i <= n ;i += lowbit(i)) t[i] += x;
}

ll getprefix(int k)
{
  ll res = 0;
  for(int i = k ; i > 0 ; i -= lowbit(i)) res += t[i];
  return res;
}

ll getsum(int l,int r)
{
  return getprefix(r) - getprefix(l-1);
}

ll oper(int k,int n)
{
  return (2*k-n-1)*a[k]-getsum(1,k-1)+getsum(k+1,n);
}


int main()
{
  // 请在此输入您的代码
  int m;
  cin >> n >> m;
  for(int i = 1 ; i <= n ; i++) 
  {
    ll x;
    cin >> x;
    update(i,x);
  }

  while(m--)
  {
    int op;
    cin >> op;
    if(op == 1)
    {
      int x;
      ll z;
      cin >> x;
      cin >> z;
      update(x,z-a[x]);
    }
    else 
    {
      int x;
      cin >> x;
      cout << oper(x,n) << '\n';
    }
  }

  return 0;
}
相关推荐
zhangrelay6 分钟前
三分钟云课实践速通--大学物理--python 版
linux·开发语言·python·学习·ubuntu·lubuntu
炽烈小老头1 小时前
【每日天学习一点算法 2026/04/27】缺失的第一个正数
学习·算法
handler011 小时前
Linux 进程探索:从 PCB 管理到 fork() 的写时拷贝
linux·c语言·c++·笔记·学习
QiZhang | UESTC1 小时前
从基础 RoPE 到 YaRN:源码学习路线揭秘
pytorch·深度学习·学习
xuhaoyu_cpp_java1 小时前
MyBatis学习(五)
经验分享·笔记·学习·mybatis
ECT-OS-JiuHuaShan1 小时前
整体论体系定理,全球开放,无法绕过
人工智能·科技·学习·算法·生活
淘矿人2 小时前
2026年4月-DeepSeek V4 vs GPT-5.5深度对比测评:weelinking一键切换实测
服务器·数据库·人工智能·python·gpt·学习·php
一只机电自动化菜鸟2 小时前
一建机电备考笔记(27)测量技术—仪器(含考频+题型)
经验分享·笔记·学习·职场和发展·求职招聘·课程设计
xiaoxiaoxiaolll2 小时前
《Light: Science & Applications》SSH模型能带首次在光子芯片上直接读出:混合频率架构赋能拓扑量子模拟
学习
Be for thing2 小时前
Android Studio 常用快捷键总结
android·学习