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 ...
随机推荐
- c++中小项堆声明和使用【转】
c++默认是大顶堆,小顶堆有两种声明方法: 1.对于基本类型直接用 priority_queue<int, vector<int>, greater<int> >p ...
- 第四天 内置函数2 随机码 装饰器 迭代器、生成器 递归 冒泡算法 JSON
关于函数的return li = [11,22,33,44] def f1(arg): arg.append(55) li = f1(li) print(li) 因为li = f1(li) 实际赋值的 ...
- android studio genymotion插件
下载andriod studio 2.2 正式版,我的版本带SDK,一直安装, 1.在设置SDK的位置. 2.安装好后在安装虚拟机插件,genymotion去官网下载不带虚拟机的. 下载地址https ...
- String.IsNullOrEmpty()和String.IsNullOrWhiteSpace()的区别
string.IsNullOrEmpty 这个是判断字符串是否为:null或者string.Empty或者“”,但不包含空格 .如果是如"\t"或者“ ” 这样的字符就返回fa ...
- springMVC+Java验证码完善注册功能
这篇文章简单的写了一个java验证码,为之前写过的springMVC注册功能加上验证码,验证码的作用就不多说了,防止机器人程序恶意注册什么的.. 其中User.java,加上了password和cod ...
- JavaEE 配置文件 应用首选项存储
JavaEE 配置文件 应用首选项存储 @author ixenos 什么是首选项? 首选项Preferences 指配置信息 首选项存储就是指对配置信息的存储 有什么方式存储? 有两种,一种存于 ...
- 8.多线程和Socket通信
一.多线程 1.进程的概念: 进程就是应用程序的执行实例,有独立的内存空间和系统资源.当一个应用程序没有执行的时候,它就不是一个进程. 2.进行的特征: (1)动态性:动态产生动态消亡. (2)并 ...
- LeetCode OJ 33. Search in Rotated Sorted Array
Suppose a sorted array is rotated at some pivot unknown to you beforehand. (i.e., 0 1 2 4 5 6 7 migh ...
- MSXML insertBefore(IXMLDOMNode *newChild, VARIANT refChild) 传参
在xml操作中经常会用到在某一个节点后或前面插入一个节点,MSXML DOM 中使用的函数是insertBefore(IXMLDOMNode *newChild, VARIANT refChild): ...
- python--sorted函数和operator.itemgetter函数
1.operator.itemgetter函数operator模块提供的itemgetter函数用于获取对象的哪些维的数据,参数为一些序号(即需要获取的数据在对象中的序号),下面看例子. a = [1 ...