hdu 1166 敌兵布阵(线段树详解)
#include <iostream>
#include <cstring>
#include <cstdio>
using namespace std; struct node //用结构体来构建一个线段树
{
int l;//左区间值,此题代表营号
int r;//右区间值,同上
int n;//值,此题代表第l个到第r个营地的总人数
} t[];//线段树的下标 void build(int l,int r,int k)//构建线段树,应用递归思想~
{
if(r==l)//左右区间值相等,此题代表单个营号
{
t[k].l=l;
t[k].r=r;
t[k].n=;//初始化,因为还没有输入营地人数
return ;//递归出口
}
t[k].l=l; // 写入第k个结点中的 左区间
t[k].r=r; // 写入第k个结点中的 右区间
t[k].n=; //初始化
int mid=(r+l)/;//将区间一分为二,这里是二分思想
build(l,mid,*k);//该结点往 左孩子的方向 继续建立线段树
build(mid+,r,*k+);// 该结点往 右孩子的方向 继续建立线段树
} void insert(int n,int d,int k)//单点更新线段树,此题的意思是改变营地人数
{
//n是变化的人数,d是营号,k=1,记住是从根本开始(递归
if(t[k].l==t[k].r&&t[k].l==d)//找到该营地
{
t[k].n+=n;//更新单点,即变化人数
return ;
}
int mid=(t[k].l+t[k].r)/;//一分为二
if(d<=mid) insert(n,d,*k);//如果营号是在左区间里,向左侧递归变化
else insert(n,d,*k+);//如果营号是在右区间里,向右侧递归变化
t[k].n=t[*k].n+t[*k+].n;//更新所有区间里值,即从下往上改变人数
} int ans; void search(int a,int b,int k)//区间查找
{
if(t[k].l==a&&t[k].r==b)//找到区间
{
ans+=t[k].n;//由于会出现区间在树中不连续,即区间被mid截断
return ;
}
int mid=(t[k].l+t[k].r)/;
if(b<=mid) search(a,b,*k);//查询区间被[L,Mid]包含,此时直接在左边查找[a,b]
else if(a>mid) search(a,b,*k+);//查询区间被[mid,r]包含,此时直接在右查找[a,b]
else//区间被mid截断
{
search(a,mid,*k);//分开查找!
search(mid+,b,*k+);
}
} int main()
{
int c,n,a,b;
char ch[];
scanf("%d",&c);
for(int m=;m<=c;m++)
{
scanf("%d",&n);
build(,n,);
int num;
for(int i=;i<=n;i++)
{
scanf("%d",&num);
insert(num,i,);
}
printf("Case %d:\n",m);
while(scanf("%s",ch),strcmp(ch,"End"))
{
scanf("%d%d",&a,&b);
if(strcmp(ch,"Add")==) insert(b,a,);
else if(strcmp(ch,"Sub")==) insert(-b,a,);
else
{
ans=;
search(a,b,);
printf("%d\n",ans);
}
}
}
return ;
}
hdu 1166 敌兵布阵(线段树详解)的更多相关文章
- HDU.1166 敌兵布阵 (线段树 单点更新 区间查询)
HDU.1166 敌兵布阵 (线段树 单点更新 区间查询) 题意分析 加深理解,重写一遍 代码总览 #include <bits/stdc++.h> #define nmax 100000 ...
- hdu 1166 敌兵布阵 线段树 点更新
// hdu 1166 敌兵布阵 线段树 点更新 // // 这道题裸的线段树的点更新,直接写就能够了 // // 一直以来想要进线段树的坑,结果一直没有跳进去,今天算是跳进去吧, // 尽管十分简单 ...
- HDU 1166 敌兵布阵(线段树单点更新,板子题)
敌兵布阵 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Submi ...
- HDU 1166 敌兵布阵(线段树单点更新)
敌兵布阵 单点更新和区间更新还是有一些区别的,应该注意! [题目链接]敌兵布阵 [题目类型]线段树单点更新 &题意: 第一行一个整数T,表示有T组数据. 每组数据第一行一个正整数N(N< ...
- HDU 1754 线段树 单点跟新 HDU 1166 敌兵布阵 线段树 区间求和
I Hate It Time Limit: 9000/3000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total ...
- HDU 1166 敌兵布阵 <线段树 单点修改 区间查询>
敌兵布阵 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submis ...
- hdu 1166 敌兵布阵 (线段树、单点更新)
敌兵布阵Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submiss ...
- hdu 1166 敌兵布阵 线段树区间修改、查询、单点修改 板子题
题目链接:敌兵布阵 题目: C国的死对头A国这段时间正在进行军事演习,所以C国间谍头子Derek和他手下Tidy又开始忙乎了.A国在海岸线沿直线布置了N个工兵营地,Derek和Tidy的任务就是要监视 ...
- HDU 1166 敌兵布阵 线段树
敌兵布阵 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submis ...
随机推荐
- C1FlexGrid小结(转自http://www.cnblogs.com/C1SupportTeam/archive/2012/12/11/2812316.html)
C1FlexGrid控件来对一个表格格式中的数据进行显示,编辑,组和总结.该表格可以绑定到一个数据源,它可以对自己的数据进行管理. C1FlexGrid控件有一个包含以下元素的丰富的对象模型: 以下的 ...
- 4.当接口的请求方式为 application/json的时候时
1..当接口的请求方式为 application/json的时候时,使用抓包软件(fiddler)获取到这个接口, 其中的Inspectprs-TextView中的内容就是jmeter中Body Da ...
- PHP中 post 与get的区别 详细说明
1.Get 方法通过 URL 请求来传递用户的数据,将表单内各字段名称与其内容,以成对的字符串连接,置于 action 属性所指程序的 url 后,如[url]http://www.jincaib.c ...
- Oracle中sys和system用户的区别
1.数据库的启动需要以SYSDBA/SYSOPER身份登录. 2.如果在同一主机上使用IPC连接到数据库使用操作系统授权,登录任何一个用户都可以拥有as sysdba和as sysoper. 3.sy ...
- AngularJs应用
引用angularjs文件 AngularJS 应用组成如下:View(视图), 即 HTML.Model(模型), 当前视图中可用的数据.Controller(控制器), 即 JavaScript ...
- Hibernate3 第四天
Hibernate3 第四天 [第一天]三个准备七个步骤 [第二天]一级缓存.一级缓存快照.一对多和多对多配置 [第三天内容回顾] 1.各种查询 对象导航查询:配置信息不能出错, 根据OID查询:ge ...
- 第14天dbutils与案例
第14天dbutils与案例 第14天dbutils与案例 1 1. 1.dbutils介绍 2 2. 2.dbutils快速入门 2 3. 3.dbutils A ...
- Sass编译Css
1.我新建了一个项目工程 2.路径在 3.编译 sass 要编译的sass文件名.scss ../存放编译后的css目录/编译后的css名称.css 4.刷新项目,就编译出来了 6.当然,你要嫌麻烦的 ...
- ggplot2 scale相关设置-坐标转换
ggplot2 scale相关设置-坐标转换 在R中坐标轴转换有多种形式,包括对数转换,平方根转换以及坐标刻度前后进行调换 用到的函数分别有: scale_x_log10(...) scale_y_l ...
- 数学#素数筛法 HDU 4548&POJ 2689
找素数本来是很简单的问题,但当数据变大时,用朴素思想来找素数想必是会超时的,所以用素数筛法. 素数筛法 打表伪代码(用prime数组保存区间内的所有素数): void isPrime() vis[]数 ...