日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

hdu1166敌兵布阵hdu1754I Hate It(线段树入门)

發(fā)布時間:2025/4/14 编程问答 25 豆豆
生活随笔 收集整理的這篇文章主要介紹了 hdu1166敌兵布阵hdu1754I Hate It(线段树入门) 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

單點更新是最最基礎的線段樹,只更新葉子節(jié)點,然后把信息用pushup這個函數(shù)更新上來。

http://acm.hdu.edu.cn/showproblem.php?pid=1166

update單點更新,query區(qū)域求和。

#include <iostream> #include <stdio.h> #include <string.h> #include <stdlib.h> #define N 200001 using namespace std; struct node {int l,r;__int64 w; } q[4*N]; void pushup(int rt) {q[rt].w=q[rt*2].w+q[rt*2+1].w; } void build(int l,int r,int rt) {q[rt].l=l;q[rt].r=r;q[rt].w=0;if(l==r){scanf("%I64d",&q[rt].w);return ;}build(l,(l+r)/2,rt*2);build((l+r)/2+1,r,rt*2+1);pushup(rt); } void update(int sum,int key,int l,int r,int rt) {if(sum<l||sum>r)return ;if(l==r&&sum==l){q[rt].w+=(__int64)key;return ;}update(sum,key,l,(l+r)/2,rt*2);update(sum,key,(l+r)/2+1,r,rt*2+1);pushup(rt); } __int64 query(int ll,int rr,int l,int r,int rt) {if(ll>r||rr<l) return 0;if(ll<=l&&rr>=r){return q[rt].w;}return query(ll,rr,l,(l+r)/2,rt*2)+query(ll,rr,(l+r)/2+1,r,rt*2+1); } int main() {int n,sum1,sum2,T,K=0;char a[10];scanf("%d",&T);while(T--){K++;scanf("%d",&n);build(1,n,1);printf("Case %d:\n",K);while(scanf("%s",a)!=EOF){if(strcmp(a,"End")==0) break;else if(strcmp(a,"Query")==0){scanf("%d%d",&sum1,&sum2);__int64 t=query(sum1,sum2,1,n,1);printf("%I64d\n",t);}else if(strcmp(a,"Sub")==0){scanf("%d%d",&sum1,&sum2);update(sum1,-sum2,1,n,1);}else if(strcmp(a,"Add")==0){scanf("%d%d",&sum1,&sum2);update(sum1,sum2,1,n,1);}}}return 0; }

?

?

http://acm.hdu.edu.cn/showproblem.php?pid=1754

update單點替換,query區(qū)間最值

#include <iostream> #include <stdio.h> #include <string.h> #include <stdlib.h> #define N 200001 using namespace std; struct node {int l,r;__int64 w; }q[4*N]; void pushup(int rt) {q[rt].w=max(q[rt*2].w,q[rt*2+1].w); } void build(int l,int r,int rt) {q[rt].l=l;q[rt].r=r;q[rt].w=0;if(l==r){scanf("%I64d",&q[rt].w);return ;}build(l,(l+r)/2,rt*2);build((l+r)/2+1,r,rt*2+1);pushup(rt); } void update(int sum,int key,int l,int r,int rt) {if(sum<l||sum>r)return ;if(l==r&&sum==l){q[rt].w=(__int64)key;return ;}update(sum,key,l,(l+r)/2,rt*2);update(sum,key,(l+r)/2+1,r,rt*2+1);pushup(rt); } __int64 query(int ll,int rr,int l,int r,int rt) {if(ll>r||rr<l) return 0;if(ll<=l&&rr>=r){return q[rt].w;}return max(query(ll,rr,l,(l+r)/2,rt*2),query(ll,rr,(l+r)/2+1,r,rt*2+1)); } int main() {int n,m,sum1,sum2;char a[3];while(scanf("%d%d",&n,&m)!=EOF){build(1,n,1);while(m--){scanf("%s%d%d",a,&sum1,&sum2);if(a[0]=='U'){update(sum1,sum2,1,n,1);}else if(a[0]=='Q'){__int64 t=query(sum1,sum2,1,n,1);printf("%I64d\n",t);}}}return 0; }

?

轉載于:https://www.cnblogs.com/zhangmingcheng/p/3902525.html

總結

以上是生活随笔為你收集整理的hdu1166敌兵布阵hdu1754I Hate It(线段树入门)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內容還不錯,歡迎將生活随笔推薦給好友。