博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
hdu 1166 敌兵布阵 (树状数组)
阅读量:6213 次
发布时间:2019-06-21

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

题目链接: 

分析:第一次接触到线段树,上网看了一些资料,发现这道题可以用树状数组来代替线段树解决,似乎用起来更方便,于是乎就找了树状数组的资料来看,这里有一个是我从网上摘抄的树状数组的资料  不是很齐全,但是初学者已经够用了。里边有基本的模板代码。

这道题是中文题目,题意很简单,就是典型的树状数组,线段树题目。

树状数组解法

#include 
#include
#include
#include
#define MAXN 50005using namespace std;int a[MAXN],c[MAXN];int N;// 树状数组模板int Low_bit(int x){ return x & (-x);}void modify(int n,int value){ while(n<=N) { c[n]+=value; n += Low_bit(n); }}int sum(int n){ int sum=0; while(n>0) { sum+=c[n]; n-=Low_bit(n); } return sum;}int query(int i,int j){ return sum(j)-sum(i-1);}int main(){ int t,x,y; scanf("%d",&t); char order[10]; for(int i=1;i<=t;i++) { printf("Case %d:\n",i); scanf("%d",&N); memset(a,0,sizeof(a)); memset(c,0,sizeof(c)); for(int j=1;j<=N;j++) { scanf("%d",&a[j]); modify(j,a[j]); } while(scanf("%s",order)&&strcmp(order,"End")!=0) { scanf("%d%d",&x,&y); if(strcmp(order,"Query")==0) printf("%d\n",query(x,y)); else if(strcmp(order,"Add")==0) modify(x,y); else if(strcmp(order,"Sub")==0) modify(x,-y); } } return 0;} 线段树解法:
#include 
#include
#include
#include
#define MAXN 50005using namespace std;typedef struct Node{ int ld,rd;//左右边界 struct Node *lc,*rc;//左右子树 int value;}Node,Tree;int num[MAXN];int N;Tree *create(int a,int b){ int mid; Node *node = (Node*)malloc(sizeof(Node)); node->ld=a; node->rd=b; if(b-a>=1) { mid=(a+b)/2; node->lc=create(a,mid); node->rc=create(mid+1,b); node->value=node->lc->value+node->rc->value; } else node->value=num[node->ld];//也可以写成 node->value=a[node->rd]; return node;}int query(Node *node,int x,int y){ if(node->ld==x && node->rd==y)return node->value; int mid = (node->ld+node->rd)/2; if(mid>=y)return query(node->lc,x,y); else if(mid
rc,x,y); else return query(node->lc,x,mid)+query(node->rc,mid+1,y);}void modify(Node *node,int x,int v){ if(node->ld==node->rd) { node->value+=v; return; } if(node->lc->rd>=x)modify(node->lc,x,v); else if(node->rc->ld<=x)modify(node->rc,x,v); node->value = node->lc->value+node->rc->value;}int main(){ int t,x,y,value; Node *root; scanf("%d",&t); char order[10]; for(int i=1;i<=t;i++) { printf("Case %d:\n",i); scanf("%d",&N); for(int j=1;j<=N;j++) scanf("%d",&num[j]); root = create(1,N); while(scanf("%s",order)&&strcmp(order,"End")!=0) { scanf("%d%d",&x,&y); if(strcmp(order,"Query")==0) printf("%d\n",query(root,x,y)); else if(strcmp(order,"Add")==0) modify(root,x,y); else if(strcmp(order,"Sub")==0) modify(root,x,-y); } } return 0;}
 

 

 
http://www.cnblogs.com/newpanderking/archive/2012/11/17/2775235.html
你可能感兴趣的文章
Maximum XOR of Two Numbers in an Array
查看>>
Reddit引入Envoy支持架构改造,性能显著提升
查看>>
Airbnb如何简化1000多位工程师的Kubernetes工作流程?
查看>>
F# 4.0于全平台发布
查看>>
音速神童创始人赵鹏王旭加入蚂蚁金服,剑指Kata Containers
查看>>
中国平安“豪赌”科技?从产险业务IT变形计聊起
查看>>
中国互联网上市科技公司市值蒸发了多少亿?
查看>>
别了MongoDB?
查看>>
Kong 发布 Kong Brain 和 Kong Immunity,可进行智能自动化和适应性监控
查看>>
.NET Core 2.1 Preview 2带来网络方面的改进
查看>>
区块链现状:从谨慎和批判性思维看待它(第二部分)
查看>>
大规模学习该如何权衡得失?解读NeurIPS 2018时间检验奖获奖论文
查看>>
O’Reilly软件架构大会第一天内容回顾
查看>>
RSocket:一个面向反应式应用程序的新型应用网络协议
查看>>
IBM首家发布了公有云中的裸机Kubernetes
查看>>
专访尤雨溪:先别管4.0了,Vue CLI重构了解一下
查看>>
机器人操作系统来到Windows
查看>>
如何打造一流的视觉AI技术
查看>>
如何使用ElasTest实现测试的可观察性
查看>>
如何打造一流的查询引擎,构建优秀的数据仓库?
查看>>