FZU2171:防守阵地 II(线段树)
Problem Description
部队中总共同拥有N个士兵,每一个士兵有各自的能力指数Xi。在一次演练中,指挥部确定了M个须要防守的地点,指挥部将选择M个士兵依次进入指定地点进行防守任务。获得的參考指数即为M个士兵的能力之和。随着时间的推移,指挥部将下达Q个指令来替换M个进行防守的士兵们。每一个參加完防守任务的士兵因为疲惫等原因能力指数将下降1。如今士兵们排成一排,请你计算出每次进行防守的士兵的參考指数。
Input
输入包括多组数据。
输入第一行有两个整数N,M,Q(1<=N<=100000。1<=M<=1000,1<=Q<=100000),第二行N个整数表示每一个士兵相应的能力指数Xi(1<=Xi<=1000)。
接下来Q行。每行一个整数X,表示在原始队列中以X为起始的M个士兵替换之前的士兵进行防守。(1<=X<=N-M+1)
对于30%的数据1<=M,N,Q<=1000。
Output
输出Q行,每行一个整数,为每次指令运行之后进行防守的士兵參考指数。
Sample Input
Sample Output
#include <stdio.h>
#include <string.h>
#include <algorithm>
using namespace std;
const int maxn = 100000+10;
int n,m,sum; struct node
{
int l,r;
int n,sum;
} a[maxn<<2]; void init(int l,int r,int i)
{
a[i].l = l;
a[i].r = r;
a[i].n = 0;
a[i].sum = 0;
if(l!=r)
{
int mid = (l+r)>>1;
init(l,mid,2*i);
init(mid+1,r,2*i+1);
}
} void insert(int i,int l,int r,int m)
{
a[i].n+=(r-l+1)*m;
if(a[i].l >= l && a[i].r <= r)
a[i].sum+=m; else
{
int mid = (a[i].l+a[i].r)>>1;
if(r<=mid)
insert(2*i,l,r,m);
else if(l>mid)
insert(2*i+1,l,r,m);
else
{
insert(2*i,l,mid,m);
insert(2*i+1,mid+1,r,m);
}
}
} int find(int i,int l,int r)
{
if(a[i].l == l && a[i].r == r)
return a[i].n;
else
{
int mid = (a[i].l+a[i].r)>>1;
if(a[i].sum)
{
a[2*i].sum += a[i].sum;
a[2*i].n+=a[i].sum*(a[2*i].r-a[2*i].l+1);
a[2*i+1].sum += a[i].sum;
a[2*i+1].n+=a[i].sum*(a[2*i+1].r-a[2*i+1].l+1);
a[i].sum = 0;
}
if(r<=mid)
return find(2*i,l,r);
else if(l>mid)
return find(2*i+1,l,r);
else
{
return find(2*i,l,mid)+find(2*i+1,mid+1,r);
}
}
} int main()
{
int i,j,x,y,q;
int k;
char str[5];
while(~scanf("%d%d%d",&n,&m,&q))
{
init(1,n,1);
for(i = 1; i<=n; i++)
{
scanf("%d",&k);
insert(1,i,i,k);
}
while(q--)
{
scanf("%d",&x);
printf("%d\n", find(1,x,x+m-1));
insert(1,x,x+m-1,-1);
}
} return 0;
}
FZU2171:防守阵地 II(线段树)的更多相关文章
- FZU Problem 2171 防守阵地 II (线段树区间更新模板题)
http://acm.fzu.edu.cn/problem.php?pid=2171 成段增减,区间求和.add累加更新的次数. #include <iostream> #include ...
- fzu 2171 防守阵地 II
Problem 2171 防守阵地 II Accept: 31 Submit: 112Time Limit: 3000 mSec Memory Limit : 32768 KB Prob ...
- UVA10869 - Brownie Points II(线段树)
UVA10869 - Brownie Points II(线段树) 题目链接 题目大意:平面上有n个点,Stan和Ollie在玩游戏,游戏规则是:Stan先画一条竖直的线作为y轴,条件是必需要经过这个 ...
- CDOJ 1259 昊昊爱运动 II 线段树+bitset
昊昊爱运动 II 昊昊喜欢运动 他N天内会参加M种运动(每种运动用一个[1,m]的整数表示) 现在有Q个操作,操作描述如下 昊昊把第l天到第r天的运动全部换成了x(x∈[1,m]) 问昊昊第l天到第r ...
- SPOJ 1557. Can you answer these queries II 线段树
Can you answer these queries II Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 https://www.spoj.com/pr ...
- bzoj 2482: [Spoj GSS2] Can you answer these queries II 线段树
2482: [Spoj1557] Can you answer these queries II Time Limit: 20 Sec Memory Limit: 128 MBSubmit: 145 ...
- 4990: [Usaco2017 Feb]Why Did the Cow Cross the Road II 线段树维护dp
题目 4990: [Usaco2017 Feb]Why Did the Cow Cross the Road II 链接 http://www.lydsy.com/JudgeOnline/proble ...
- hdu 5831 Rikka with Parenthesis II 线段树
Rikka with Parenthesis II 题目连接: http://acm.hdu.edu.cn/showproblem.php?pid=5831 Description As we kno ...
- 【CF687D】Dividing Kingdom II 线段树+并查集
[CF687D]Dividing Kingdom II 题意:给你一张n个点m条边的无向图,边有边权$w_i$.有q个询问,每次给出l r,问你:如果只保留编号在[l,r]中的边,你需要将所有点分成两 ...
随机推荐
- Codeforces Round #424 A(模拟)
#include<cstdio> ]; int main(){ scanf("%d",&n); ;i<=n;++i)scanf("%d" ...
- 主席树+LCA【p2633 (bzoj2588】 Count on a tree
Description 给定一棵N个节点的树,每个点有一个权值,对于M个询问(u,v,k),你需要回答u xor lastans和v这两个节点间第K小的点权.其中lastans是上一个询问的答案,初始 ...
- 洛谷——P3914 染色计数
P3914 染色计数 题目描述 有一颗NN个节点的树,节点用1,2,\cdots,N1,2,⋯,N编号.你要给它染色,使得相邻节点的颜色不同.有MM种颜色,用1,2,\cdots,M1,2,⋯,M编号 ...
- ASP.NET Core 2.2 基础知识(六) 配置(内含MySql+EF)
先上一段代码,了解一下 .NET Core 配置数据的结构. 新建一个 控制台项目,添加一个文件 json.json ,文件内容如下: { "country": "cn& ...
- ZOJ 3949 Edge to the Root(树形DP)
[题目链接] http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode=3949 [题目大意] 给出一棵根为1的树,每条边边长为1,请你 ...
- 1.5 JSP标准标签库(JSTL)(核心标签 out、set、remove、if、choose、forEach、forTokens、redirect)
JSTL(JavaServer Page Standard Tag Library):JSP标准标签库.它封装了JSP应用的通用核心功能. 1.准备工作 使用JSTL前需要下载所需文件,下载地址及安 ...
- Problem H: 计算数列和2/1,3/2,5/3,8/5......
#include<stdio.h> int main(){ int i,n; scanf("%d",&n); float sum=0.0; ; ; ;i< ...
- MR实现--矩阵乘法
import java.io.IOException; import org.apache.hadoop.conf.Configuration; import org.apache.hadoop.io ...
- Scala实战高手****第1课:大数据时代的“黄金”语言Scala
共计28课,每节课程在1个小时左右. 每天至少2个课程.预计在11.30号完成. ——————————————————
- jeeplus中两个项目redis冲突问题
修改端口号[两个项目使用不同的database]