Codevs1080 线段树练习

来源:互联网 发布:宽带网络校校通 编辑:程序博客网 时间:2024/04/30 04:08

这个是线段树or树状数组裸题

good

树状数组 (刚学的O(∩_∩)O嗯!)

//歪鸡劈//don't copy//or you'll 滚蛋//¥¥¥#include<iostream>#include<cstdio>#include<cstdlib>#include<cmath>#include<algorithm>#include<cstring>#include<vector>#include<queue>#ifdef WIN32   #define OUT "%I64d"#else#define OUT "%lld"#endif#define LL long long #define maxn 100010using namespace std;int getint(){    int w=0,q=0;char ch=getchar();    while((ch<'0'||ch>'9')&&ch!='-')ch=getchar();    if(ch=='-')q=1,ch=getchar();    while(ch>='0'&&ch<='9')w=w*10+ch-'0',ch=getchar();    return q?-w:w;}int a[maxn],low[maxn],sum[maxn],c[maxn];int n,i,m;int lowbit(int kk){    return kk&(~kk+1);//  ||(-kk)&kk}void Init(){    n=getint();sum[0]=0;    for(i=1;i<=n;i++)        a[i]=getint(),low[i]=lowbit(i),sum[i]=sum[i-1]+a[i];    //low数组小优化    m=getint();}void Preparation(){    // 初始化 有两种(First 前缀和O(n) Second plus(这一位)O(nlogn))    for(i=1;i<=n;i++)        c[i]=sum[i]-sum[i-low[i]];}void Plus(int x,int k){    a[x]+=k;    while(x<=n){        c[x]+=k;        x+=low[x];    }}int ans;int Src(int x){    ans=0;    while(x)    {        ans+=c[x];        x-=low[x];    }    return ans;}int flag,x,k;void Work(){    while(m--)    {        flag=getint();        if(flag==1)        {            x=getint();k=getint();            Plus(x,k);        }else{            x=getint();k=getint();            printf("%d\n",Src(k)-Src(x-1));        }    }}int main(){    freopen("ma.in","r",stdin);    freopen("ma.out","w",stdout);    Init();    Preparation();    Work();    return 0;}

线段树

//歪鸡劈//don't copy//or you'll 滚蛋#include<iostream>#include<cstdio>#include<cstdlib>#include<cmath>#include<algorithm>#include<cstring>#include<vector>#define maxn 100010using namespace std;int n,m,i,a[maxn];int go,l,r,x,A;struct Edge{  int l,r,c,mid,kk;}tree[maxn*4];int getint(){    int w=0,q=0;char ch=getchar();    while((ch<'0'||ch>'9')&&ch!='-')ch=getchar();    if(ch=='-')q=1,ch=getchar();    while(ch>='0'&&ch<='9')w=w*10+ch-'0',ch=getchar();    return q?-w:w;}void Init(){  n=getint();  for(i=1;i<=n;i++)a[i]=getint();  m=getint();}int Build_tree(int l,int r,int k){  tree[k].l=l;tree[k].r=r;  if(l==r){tree[k].c=a[l];return a[l];}  int mid=(l+r)>>1,kk=k<<1;  tree[k].mid=mid;tree[k].kk=kk;  tree[k].c=Build_tree(l,mid,kk)+Build_tree(mid+1,r,kk+1);  return tree[k].c;}void before(){  Build_tree(1,n,1);}int find(int l,int r,int k){  if(l==tree[k].l&&r==tree[k].r)      return tree[k].c;  if(r<=tree[k].mid)    return find(l,r,tree[k].kk);  else{    if(l<=tree[k].mid)return find(l,tree[k].mid,tree[k].kk)+find(tree[k].mid+1,r,tree[k].kk+1);    else return find(l,r,tree[k].kk+1);  }  return 0;}void change(int pos,int up,int k){  if(tree[k].l==tree[k].r)    {      tree[k].c+=up;      return;    }  if(pos<=tree[k].mid)    {      change(/*tree[k].l,tree[k].mid,*/pos,up,tree[k].kk);      tree[k].c+=up;    }  else    {      change(/*tree[k].mid+1,tree[k].r,*/pos,up,tree[k].kk+1);      tree[k].c+=up;    }}void Work(){  while(m--)    {      go=getint();      go--;      if(go)//2询问    {      l=getint();r=getint();      printf("%d\n",find(l,r,1));    }      else//1改变    {      x=getint();A=getint();      change(x,A,1);    }    }}int main(){    freopen("yjp.in","r",stdin);    freopen("yjp.out","w",stdout);    Init();    before();    Work();    return 0;}> 这是一个gang
1 0
原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 吃过敏药嗜睡乏力怎么办 写字紧张心跳的快手抖怎么办 怀孕食欲差没精神怎么办 爬个三楼就喘了怎么办 头被篮球砸了怎么办 打球手指肿了很久怎么办 客人吃饭跑单了怎么办 脑子总是记不住东西怎么办 穿的鞋有味道怎么办 生完孩子血糖高怎么办 生了孩子子宫大怎么办 生完孩子阴吹怎么办 怀孕初期感冒嗓子发炎怎么办 脑子转不过来弯怎么办 他说我道行不深怎么办 鞋子内测磨破了怎么办 老公拉肚子拉的很厉害怎么办 老公拉肚子拉得很厉害怎么办 和老公吵架很厉害怎么办 新鞋鞋底吱吱响怎么办 新鞋鞋底滑了怎么办 工作中同事不配合怎么办 做体力活一身疼怎么办 大脑左则中动脉血管狭窄?怎么办 儿童体质差免疫力差怎么办 nba篮球大师体力不够怎么办 一千米差10秒怎么办 四十岁以后体力和耐力差怎么办 打篮球一打比赛就紧张怎么办 耐克空军鞋鞋底边胶掉了怎么办 鞋底踩到老鼠胶怎么办 头蒙怎么办最快最有效 备孕老公压力大怎么办 宝宝太兴奋不睡怎么办 我很烦只睡三小时觉怎么办才好 柯基精力太旺盛怎么办 孩子学习熬夜精力不足怎么办 肺癌晚期吃不下饭怎么办 这俩天吃药太多肝肾功能不好怎么办 跑步跑得头疼晕怎么办 吃完辣的想吐怎么办