HDU 1166 敌兵布阵(线段树 or 二叉索引树)
http://acm.hdu.edu.cn/showproblem.php?pid=1166
题意:
第一行一个整数T,表示有T组数据。
每组数据第一行一个正整数N(N<=50000),表示敌人有N个工兵营地,接下来有N个正整数,第i个正整数ai代表第i个工兵营地里开始时有ai个人(1<=ai<=50)。
接下来每行有一条命令,命令有4种形式:
(1) Add i j,i和j为正整数,表示第i个营地增加j个人(j不超过30)
(2)Sub i j ,i和j为正整数,表示第i个营地减少j个人(j不超过30);
(3)Query i j ,i和j为正整数,i<=j,表示询问第i到第j个营地的总人数;
(4)End 表示结束,这条命令在每组数据最后出现;
思路:
这道题目用线段树和二叉索引树都是可以做的,给出两种做法。
#include<iostream>
#include<cstring>
#include<algorithm>
using namespace std; const int maxn = << ; int n; struct node
{
int l, r;
int num;
}tree[maxn]; char s[];
int ans; void build_tree(int l,int r,int k)
{
tree[k].l = l;
tree[k].r = r;
tree[k].num = ; if(l==r) return; int mid = (l + r) / ;
build_tree(l, mid, * k);
build_tree(mid + , r, * k + );
} void insert(int x, int i, int k)
{
if (tree[k].l == tree[k].r && tree[k].l == i)
{
tree[k].num += x;
return;
}
int mid = (tree[k].l + tree[k].r) / ;
if (i <= mid) insert(x, i, * k);
else insert(x, i, * k + );
tree[k].num = tree[ * k].num + tree[ * k + ].num;
} void search(int l,int r,int k)
{
if (tree[k].l == l && tree[k].r == r)
{
ans += tree[k].num;
return;
}
int mid = (tree[k].l + tree[k].r) / ;
if (r <= mid) search(l, r, * k);
else if(l > mid) search(l, r, * k + );
else
{
search(l, mid, * k);
search(mid + , r, * k + );
}
} int main()
{
//freopen("D:\\txt.txt", "r", stdin);
int T;
scanf("%d", &T);
int x, y;
int kase = ;
while (T--)
{
scanf("%d", &n);
build_tree(, n, );
int a;
for (int i = ; i <= n; i++)
{
cin >> a;
insert(a, i, );
}
printf("Case %d:\n", ++kase);
while (scanf("%s",&s) && s[] != 'E')
{
scanf("%d%d", &x, &y);
if (s[] == 'Q')
{
ans = ;
search(x, y, );
cout << ans << endl;
}
else if (s[] == 'A')
{
insert(y, x, );
}
else
{
insert(-y, x, );
}
}
}
}
#include<iostream>
#include<cstring>
#include<algorithm>
using namespace std; const int maxn = + ; int c[maxn];
int n;
char s[]; int lowbit(int x)
{
return x&-x;
} int sum(int x)
{
int num = ;
while (x > )
{
num += c[x];
x -= lowbit(x);
}
return num;
} void add(int x, int d)
{
while (x <= n)
{
c[x] += d;
x += lowbit(x);
}
} int main()
{
//freopen("D:\\txt.txt", "r", stdin);
int T;
scanf("%d", &T);
int x, y;
int kase = ;
while (T--)
{
memset(c, , sizeof(c));
cin >> n;
int a;
for (int i = ; i <= n; i++)
{
cin >> a;
add(i, a);
}
printf("Case %d:\n", ++kase);
while (scanf("%s",&s) && s[] != 'E')
{
scanf("%d%d", &x, &y);
if (s[] == 'Q')
{
cout << sum(y) - sum(x - ) << endl;
}
else if (s[] == 'A')
{
add(x, y);
}
else
{
add(x, -y);
}
}
}
}
HDU 1166 敌兵布阵(线段树 or 二叉索引树)的更多相关文章
- 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 ...
- HDU 1166 敌兵布阵(线段树)
题目地址:pid=1166">HDU 1166 听说胡浩版的线段树挺有名的. 于是就拜訪了一下他的博客.详情戳这里.于是就全然仿照着胡浩大牛的风格写的代码. 至于原理.鹏鹏学长已经讲的 ...
随机推荐
- ios Quartz 各种绘制图形用法
摘要: CoreGraphics的功能非常强大,可以绘制各种图形:今天学习一下怎么绘制简单的点线面,记录学习. 一.导入coreGraphics.framework 二.绘制图形 1.绘制矩形 // ...
- IDEA Tomcat部署时war和war exploded区别以及平时踩得坑
war和war exploded的区别 在使用IDEA开发项目的时候,部署Tomcat的时候通常会出现下边的情况: 是选择war还是war exploded 这里首先看一下他们两个的区别: war模式 ...
- CH5E07 划分大理石【多重背包】
5E07 划分大理石 0x5E「动态规划」练习描述有价值分别为1..6的大理石各a[1..6]块,现要将它们分成两部分,使得两部分价值之和相等,问是否可以实现.其中大理石的总数不超过20000. 输入 ...
- 沈阳网络赛I-Lattice's basics in digital electronics【模拟】
42.93% 1000ms 131072K LATTICE is learning Digital Electronic Technology. He is talented, so he under ...
- java web 打印(lodop)案例
应需求接触到lodop 打印. 首先在lodop官网下载相关文件(js.css等):http://www.lodop.net/download.html 在下载好的包里 除了html页面 其他的j ...
- Eclipse Tomcat插件的配置, 及 Tomcat 的配置
Eclipse Tomcat插件的配置, 及 Tomcat 的配置 首先下载 对应 eclipse 版本的 tomcat 插件版本,(这里要注意: Tomcat 插件是Tomcat 插件,Tomc ...
- Jamie's Contact Groups---hdu1669--poj2289(多重匹配+二分)
题目链接 题意:Jamie有很多联系人,但是很不方便管理,他想把这些联系人分成组,已知这些联系人可以被分到哪个组中去,而且要求每个组的联系人上限最小,即有一整数k,使每个组的联系人数都不大于k,问这个 ...
- SQL基础--查询之二--连接查询
SQL基础--查询之二--连接查询
- (windows下)tomcat优化--内存,并发.缓存三方面优化
一.内存 注: jdk1.8中废弃了-XX:PermSize和-XX:MaxPermSize的持久态(存放常量.静态变量区)配置, 多了一个元数据区(Metadata Space:默认为内存的0.2% ...
- nodejs Async详解之三:集合操作
Async提供了很多针对集合的函数,可以简化我们对集合进行异步操作时的步骤.如下: forEach:对集合中每个元素进行异步操作 map:对集合中的每个元素通过异步操作得到另一个值,得到新的集合 fi ...