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. zabbix修改和查看登录密码

    author:hendsen chen date : 2018-08-30  16:48:18 1,登陆zabbix的服务器,查看zabbix的登陆密码: [root@jason ~]# mysql ...

  2. tortoiseSVN如何发现和解决冲突?

    版本冲突原因: 假设A.B两个用户都在版本号为100的时候,更新了kingtuns.txt这个文件,A用户在修改完成之后提交kingtuns.txt到服务器,这个时候提交成功,这个时候kingtuns ...

  3. mycelipse中关于编码的配置

    (1)修改工作空间的编码方式: Window->Preferences->General->Workspace->Text file Encoding在Others里选择需要的 ...

  4. yii2中的别名路径,@webroot , @web

    定义在yii\web\Application 的bootstrap中, Yii::setAlias('@webroot', dirname($request->getScriptFile())) ...

  5. 系统性能优化- Session丢失

    最近在做项目的过程中,客户经常反馈在操作的时候进场会突然跳转到登录页面. 先描述下系统情况: 操作系统:WindowsServer 2008 .NET版本:.NET 4.0/ASP.NET 4.0/A ...

  6. Docker容器之Nginx

    一,pull一个Nginx镜像 docker pull nginx 二,Nginx镜像文件说明 配置文件 /etc/nginx/nginx.conf 网站根目录 /usr/share/nginx/ht ...

  7. CH1809匹配统计【KMP】

    1809 匹配统计 0x18「基本数据结构」练习 描述 阿轩在纸上写了两个字符串,分别记为A和B.利用在数据结构与算法课上学到的知识,他很容易地求出了“字符串A从任意位置开始的后缀子串”与“字符串B” ...

  8. 焦作网络赛E-JiuYuanWantstoEat【树链剖分】【线段树】

    You ye Jiu yuan is the daughter of the Great GOD Emancipator. And when she becomes an adult, she wil ...

  9. #pragma once含义及用法

    #pragma once是一个比较常用的C/C++杂注,只要在头文件的最开始加入这条杂注,就能够保证头文件只被编译一次. #pragma once是编译器相关的,有的编译器支持,有的编译器不支持,具体 ...

  10. iptables 执行清除命令 iptables -F 要非常小心的

    iptables 执行清除命令 iptables -F 要非常小心的 http://blog.csdn.net/netingcn/article/details/5692972 使用 /sbin/ip ...