(线段树)敌兵布阵--hdu--1166 (入门)
链接:
http://acm.hdu.edu.cn/showproblem.php?pid=1166
自己第一次在没有看题解AC出来的线段树,写的可能不是太好,再贴个学长的代码,学习一下
发现自己的Update部分写了很多废话,直接用a[r]里的值就好了,我还传了那么多的值,真傻!
代码:
#include<stdio.h>
#include<algorithm>
#include<stdlib.h>
#include<string.h>
using namespace std; #define Lson r<<1
#define Rson r<<1|1 const int N = 1e6+; struct SegmentTree
{
int L, R;
int sum, e;
int Mid()
{
return (R+L)>>;
}
}a[N<<]; void BuildSegTree(int r, int L, int R)
{
a[r].L=L, a[r].R=R;
a[r].e=; if(L==R)
{
scanf("%d", &a[r].sum);
return ;
} BuildSegTree(Lson, L, a[r].Mid());
BuildSegTree(Rson, a[r].Mid()+, R); a[r].sum = a[Lson].sum + a[Rson].sum;
} void Update(int r, int L, int R, int i, int e)
{
a[r].sum += e; if(L==R && L==i)
return ; if(i<=a[r].Mid())
Update(Lson, L, a[r].Mid(), i, e);
else if(i>a[r].Mid())
Update(Rson, a[r].Mid()+, R, i, e);
} int Query(int r, int L, int R)
{
if(a[r].L==L && a[r].R==R)
return a[r].sum; if(R<=a[r].Mid())
return Query(Lson, L, R);
else if(L>a[r].Mid())
return Query(Rson, L, R);
else
{
long long Lsum = Query(Lson, L, a[r].Mid());
long long Rsum = Query(Rson, a[r].Mid()+, R); return Lsum + Rsum;
}
} int main()
{
int t, k=;
scanf("%d", &t);
while(t--)
{
int n;
scanf("%d", &n);
BuildSegTree(, , n); char s[];
int L, R, i, e; printf("Case %d:\n", k++); while(scanf("%s", s), strcmp(s, "End"))
{
if(strcmp(s, "Query")==)
{
scanf("%d%d", &L, &R);
printf("%d\n", Query(, L, R));
}
else if(strcmp(s, "Add")==)
{
scanf("%d%d", &i, &e);
Update(, , n, i, e);
}
else
{
scanf("%d%d", &i, &e);
Update(, , n, i, -e);
}
}
}
return ;
}
学长的代码:
#include<stdio.h>
#include<math.h>
#include<string.h> #define maxn 50005 struct node
{
int L, R, sum;//左右子树,sum记录区间和
int Mid(){return (L+R)/;}
}tree[maxn*];//为了保险起见一般定义是四倍
int val[maxn];//保存每个阵地原来的人数 void Build(int root, int L, int R)//建树
{
tree[root].L = L, tree[root].R = R; if(L == R)
{
tree[root].sum = val[L];
return ;
} Build(root<<, L, tree[root].Mid());//<<1 运算符相当于乘上 2,因为是数往左移一位
Build(root<<|, tree[root].Mid()+, R);//|1, 因为左移后最后一位是0, 所以与1进行|相当于+1 tree[root].sum = tree[root<<].sum+tree[root<<|].sum;//区间和等于左右区间的和
}
//k表示需要更新的点,e表示需要更新的值
void Insert(int root, int k, int e)
{
tree[root].sum += e;
if(tree[root].L == tree[root].R)
return ; if(k <= tree[root].Mid())
Insert(root<<, k, e);
else
Insert(root<<|, k, e);
}
//查询区间LR的和
int Query(int root, int L, int R)
{
if(tree[root].L == L && tree[root].R == R)
return tree[root].sum; //如果在左子树区间
if(R <= tree[root].Mid())
return Query(root<<, L, R);
else if(L > tree[root].Mid())//如果在右子树区间
return Query(root<<|, L, R);
else
{//在左右子树
int Lsum = Query(root<<, L, tree[root].Mid());
int Rsum = Query(root<<|, tree[root].Mid()+, R); return Lsum + Rsum;
}
} int main()
{
int T, t=; scanf("%d", &T); while(T--)
{
int i, N, x, y; scanf("%d", &N); for(i=; i<=N; i++)
scanf("%d", &val[i]);
Build(, , N); char s[]; printf("Case %d:\n", t++); while(scanf("%s", s), s[] != 'E')
{
scanf("%d%d", &x, &y); if(s[] == 'A')
Insert(, x, y);
else if(s[] == 'S')
Insert(, x, -y);
else
{
int ans = Query(, x, y);
printf("%d\n", ans);
}
}
} return ;
}
(线段树)敌兵布阵--hdu--1166 (入门)的更多相关文章
- 敌兵布阵 HDU 1166 线段树
敌兵布阵 HDU 1166 线段树 题意 这个题是用中文来描写的,很简单,没什么弯. 解题思路 这个题肯定就是用线段树来做了,不过当时想了一下可不可用差分来做,因为不熟练就还是用了线段树来做,几乎就是 ...
- A - 敌兵布阵 HDU - 1166 线段树(多点修改当单点修改)
线段树板子题练手用 #include<cstdio> using namespace std; ; int a[maxn],n; struct Node{ int l,r; long lo ...
- 敌兵布阵 HDU - 1166 (树状数组模板题,线段树模板题)
思路:就是树状数组的模板题,利用的就是单点更新和区间求和是树状数组的强项时间复杂度为m*log(n) 没想到自己以前把这道题当线段树的单点更新刷了. 树状数组: #include<iostrea ...
- A - 敌兵布阵 - hdu 1166
Description C国的死对头A国这段时间正在进行军事演习,所以C国间谍头子Derek和他手下Tidy又开始忙乎了.A国在海岸线沿直线布置了N个工兵营地,Derek和Tidy的任务就是要监视这些 ...
- 敌兵布阵 HDU - 1166 板子题
#include <cstdio> #include <cstring> #include <iostream> #include <algorithm> ...
- HDU 1754 线段树 单点跟新 HDU 1166 敌兵布阵 线段树 区间求和
I Hate It Time Limit: 9000/3000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total ...
- A - 敌兵布阵(HDU 1166)
A - 敌兵布阵 HDU - 1166 思路:线段树单点修改+区间查询. #include<cstdio> #include<cstring> #include<iost ...
- hdu 1166:敌兵布阵(树状数组 / 线段树,入门练习题)
敌兵布阵 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submis ...
- hdu acm 1166 敌兵布阵 (线段树)
敌兵布阵 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Submi ...
随机推荐
- 软件工程导论复习 如何画系统流程图和数据流图 part2
数据流图(DFD) 数据流图,简称DFD,是SA方法中用于表示系统逻辑模型的一种工具,它以图形的方式描绘数据在系统中流动和处理的过程,由于它只反映系统必须完成的逻辑功能,所以它是一种功能模型.下 ...
- 【Java】JVM(二)、Java垃圾收集算法
一.标记-清除算法 算法主要分为两个步骤 1. 标记: 遍历所有的 GC Roots, 然后标记所有可达对象为存活对象 2. 清除: 遍历堆中所有对象,然后将没有标记的对象清除. 存在不足: 1. 效 ...
- kubeadmin 部署(centos 7)
安装指定版本docker:# yum list docker-ce --showduplicates | sort -ryum install docker-ce-18.06.1.ce-3.el7vi ...
- Linux运维就业技术指导(八):期中架构考核
一,期中架构考核概述 1.1 架构图 1.2 架构图公司背景概述 公司是一个新兴的人脸识别高新创业公司,公司名称xxxx 老总是博士生导师,还有一个副总是研究生导师 副总同时是研发总监,负责所有的研发 ...
- richface的配置、用法介绍和注意事项
richface的配置.用法介绍和注意事项一.RichFaces (3.1.x) 技术需求 1.JDK 1.5 或更高版本: 2.支持的 JSF 实现: Sun JSF 1.1 RI - 1.2 My ...
- The value for the useBean class attribute is invalid.
报错如下: The value for the useBean class attribute com.JavaBeanTest is invalid. 解决方法: 在JavaBean代码中加入无参数 ...
- 在Eclipse中配置Maven插件
--------------------------siwuxie095 在 Eclipse 中配置 Maven 插件 ...
- 使用DW工具给图片添加热点MAP
一.准备一张图片. 准备一张需要给不同区域添加不同热点的图片. 二.插入图片: 打开Dreamweaver,新建一个网页,将图片插入到页面中. 三.找到地图工具: 单击鼠标左键点击图片,这时候 ...
- 简述Markdown的使用方法
MarkdownPad Document Markdown的使用技巧 一.标题 一个”#“表示H1.“##”表示H2... 二.列表 第一点 第二点 注意1.2. -与文本之间要有一个空格 这一点 三 ...
- 帧动画布局文件 animation-list
<?xml version="1.0" encoding="utf-8"?><animation-list xmlns:android=&qu ...