博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
[HDU 1166] 敌兵布阵
阅读量:6253 次
发布时间:2019-06-22

本文共 2579 字,大约阅读时间需要 8 分钟。

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1166

 

一个线段树区间求和的模板题了。

1 #include
2 #include
3 #include
4 using namespace std; 5 6 #define MID(l,r) (l+r)>>1 7 #define lson root<<1 8 #define rson root<<1|1 9 10 const int maxn=5e4+5; 11 struct Tree 12 { 13 int l,r; 14 int sum; 15 }tree[maxn*3]; 16 17 int arr[maxn],ans; 18 19 void Build(int root,int l,int r) 20 { 21 tree[root].l=l; 22 tree[root].r=r; 23 if(l==r) 24 tree[root].sum=arr[l]; 25 else 26 { 27 int mid=MID(l,r); 28 Build(lson,l,mid); 29 Build(rson,mid+1,r); 30 tree[root].sum=tree[lson].sum+tree[rson].sum; 31 } 32 } 33 34 void Query(int root,int x,int y) 35 { 36 if(x<=tree[root].l&&y>=tree[root].r) 37 ans+=tree[root].sum; 38 else 39 { 40 int mid=MID(tree[root].l,tree[root].r); 41 if(x>mid) 42 { 43 Query(rson,x,y); 44 } 45 else if(y<=mid) 46 { 47 Query(lson,x,y); 48 } 49 else 50 { 51 Query(lson,x,y); 52 Query(rson,x,y); 53 } 54 } 55 } 56 57 void Update(int root,int x,int y) 58 { 59 tree[root].sum+=y; 60 if(tree[root].l==x&&tree[root].r==x) 61 return ; 62 int mid=MID(tree[root].l,tree[root].r); 63 if(x>mid) 64 Update(rson,x,y); 65 else 66 Update(lson,x,y); 67 68 } 69 70 int main() 71 { 72 int T; 73 cin>>T; 74 for(int flag=1;flag<=T;flag++) 75 { 76 int n; 77 cin>>n; 78 for(int i=1;i<=n;i++) 79 scanf("%d",&arr[i]); 80 Build(1,1,n); 81 printf("Case %d:\n",flag); 82 char s[10]; 83 while(scanf("%s",s)!=EOF) 84 { 85 if(strcmp(s,"End")==0) 86 break; 87 else if(strcmp(s,"Add")==0) 88 { 89 int x,y; 90 scanf("%d%d",&x,&y); 91 Update(1,x,y); 92 } 93 else if(strcmp(s,"Sub")==0) 94 { 95 int x,y; 96 scanf("%d%d",&x,&y); 97 Update(1,x,-y); 98 } 99 else if(strcmp(s,"Query")==0)100 {101 int x,y;102 scanf("%d%d",&x,&y);103 ans=0;104 Query(1,x,y);105 printf("%d\n",ans);106 }107 }108 }109 return 0;110 }

 

转载于:https://www.cnblogs.com/youpeng/p/10505984.html

你可能感兴趣的文章
TCP有限状态机
查看>>
XenServer常用Debug问题的命令介绍
查看>>
算法分析-快速排序QUICK-SORT
查看>>
Web服务基础六之编译安装配置RHEL+Apache+MySQL+PHP+ZendOptimize
查看>>
log4net 使用
查看>>
通过bat文件运行jar包程序
查看>>
关于hive RegexSerDe的源码分析
查看>>
V$INSTANCE视图
查看>>
OpenCart之侧边浮动联系我们表单(Side Contact Us Form)
查看>>
PureWhite OpenCart 商城自适应主题模板 ABC-0009
查看>>
docker整理文档
查看>>
zabbix安装配置
查看>>
Awk练习笔记
查看>>
RAID级别详解,如何在Linux下实现软RAID图文解析。
查看>>
CentOS 配置***客户端
查看>>
线上应用故障排查之二:高内存占用
查看>>
书写「简历」时,需要规避的错误
查看>>
我的友情链接
查看>>
老毛桃 win7
查看>>
continue
查看>>