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 二叉索引树)的更多相关文章

  1. HDU.1166 敌兵布阵 (线段树 单点更新 区间查询)

    HDU.1166 敌兵布阵 (线段树 单点更新 区间查询) 题意分析 加深理解,重写一遍 代码总览 #include <bits/stdc++.h> #define nmax 100000 ...

  2. hdu 1166 敌兵布阵 线段树 点更新

    // hdu 1166 敌兵布阵 线段树 点更新 // // 这道题裸的线段树的点更新,直接写就能够了 // // 一直以来想要进线段树的坑,结果一直没有跳进去,今天算是跳进去吧, // 尽管十分简单 ...

  3. HDU 1166 敌兵布阵(线段树单点更新,板子题)

    敌兵布阵 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Submi ...

  4. HDU 1166 敌兵布阵(线段树单点更新)

    敌兵布阵 单点更新和区间更新还是有一些区别的,应该注意! [题目链接]敌兵布阵 [题目类型]线段树单点更新 &题意: 第一行一个整数T,表示有T组数据. 每组数据第一行一个正整数N(N< ...

  5. HDU 1754 线段树 单点跟新 HDU 1166 敌兵布阵 线段树 区间求和

    I Hate It Time Limit: 9000/3000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total ...

  6. HDU 1166 敌兵布阵 <线段树 单点修改 区间查询>

    敌兵布阵 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Submis ...

  7. hdu 1166 敌兵布阵 (线段树、单点更新)

    敌兵布阵Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Submiss ...

  8. hdu 1166 敌兵布阵 线段树区间修改、查询、单点修改 板子题

    题目链接:敌兵布阵 题目: C国的死对头A国这段时间正在进行军事演习,所以C国间谍头子Derek和他手下Tidy又开始忙乎了.A国在海岸线沿直线布置了N个工兵营地,Derek和Tidy的任务就是要监视 ...

  9. HDU 1166 敌兵布阵 线段树

    敌兵布阵 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Submis ...

  10. HDU 1166 敌兵布阵(线段树)

    题目地址:pid=1166">HDU 1166 听说胡浩版的线段树挺有名的. 于是就拜訪了一下他的博客.详情戳这里.于是就全然仿照着胡浩大牛的风格写的代码. 至于原理.鹏鹏学长已经讲的 ...

随机推荐

  1. js获取元素的外链样式

    一般给元素设置行内样式,如<div id="div1" style="width:500px;"></div>.如要获取它的样式,即可d ...

  2. 170705、springboot编程之自定义properties

    spring boot使用application.properties默认了很多配置.但需要自己添加一些配置的时候,可以这样用,如下! 在application.properties文件中增加信息 1 ...

  3. 了解MIP(Mobile Instant Pages)

    mip官网:https://www.mipengine.org/   什么是mip? mip是百度在2016年提出的移动网页加速器项目.可以简单理解为是一个规范.   mip能做什么? mip能帮助站 ...

  4. ora-28056错误解决

    问题描述:今天有同事找我,说是oracle数据库的监听器出现问题,我连接服务器查看后,发现不是监听器问题,而是进程连接数已经达到150个了,客户端连接不上服务器,因其是测试服务器,重启服务器后再次sq ...

  5. teamviewer and openconnect-gp (globalprotect) in ubuntu

    wget https://download.teamviewer.com/download/teamviewer_i386.deb sudo dpkg -i teamviewer_i386.deb a ...

  6. 数据库们~MySQL~MongoDB~Redis

    mysql基础 mysql进阶 python操作mysql MongoDB Redis

  7. jQuery至上宝典

    一 jQuery是什么? <1> jQuery由美国人John Resig创建,至今已吸引了来自世界各地的众多 javascript高手加入其team. <2>jQuery是继 ...

  8. python os模块 os.chmod

    os.chmod() 方法用于更改文件或目录的权限. os.chmod(path, mode) 参数 path -- 文件名路径或目录路径. flags -- 可用以下选项按位或操作生成, 目录的读权 ...

  9. Myeclipse文档注释如何提炼(导出)成自己的API帮助文档?

    第一步: 源码注释规范,一定要用/** 两个*这一特殊的注释.注释上可以添加@author等特殊说明,下图是部分 javadoc 标记 信息,可以根据需要选用.   第二步: 确保整个工程的项目都添加 ...

  10. 谷歌百度以图搜图 "感知哈希算法" C#简单实现

    /// <summary> /// 感知哈希算法 /// </summary> public class ImageComparer { /// <summary> ...