FOJ 2171 防守阵地 II 区间求和区间查询 线段树

题目链接:http://acm.fzu.edu.cn/problem.php?pid=2171

题意:

给定n长序列,常数m,q个询问

对于每个询问x

1、求[x, x+m-1] 区间和

2、[x,x+m-1]区间的所有元素-1

线段树裸题,不知为何全用longlong会re,只能改成部分longlong

#include<stdio.h>
#include<string.h>
#define ll long long
#define LL int
#define L(x) (x*2)
#define R(x) (x*2+1)
#define N 100100
LL Mid(LL a,LL b){return (a+b)/2;}
struct node{
	LL l, r;
	ll sum, val;
	ll size(){return (ll)r-(ll)l+1;}
}tree[N*4];
ll a[N];
void push_up(LL x){
	tree[x].val = tree[L(x)].val + tree[R(x)].val;
}
void push_down(LL id){
	if(tree[id].sum){
		tree[L(id)].sum += tree[id].sum;
		tree[R(id)].sum += tree[id].sum;
		tree[L(id)].val += tree[id].sum*tree[L(id)].size();
		tree[R(id)].val += tree[id].sum*tree[R(id)].size();
		tree[id].sum = 0;
	}
}
void build(LL l, LL r, LL id){
	tree[id].l = l, tree[id].r = r; tree[id].sum = 0;
	if(l==r){tree[id].val = a[l]; return;}
	LL mid = Mid(l,r);
	build(l,mid,L(id));
	build(mid+1,r,R(id));
	push_up(id);
}
ll query(LL l, LL r, LL id){
	if(l == tree[id].l && tree[id].r == r)return tree[id].val;
	push_down(id);

	LL mid = Mid(tree[id].l, tree[id].r);
	if(r <= mid)return query(l,r,L(id));
	else if(mid < l)return query(l, r, R(id));
	return query(l,mid,L(id))+query(mid+1,r,R(id));
}
void updata(LL l, LL r, LL id){
	if(l == tree[id].l && tree[id].r == r){
		tree[id].val -= tree[id].size();
		tree[id].sum --;
		return;
	}
	push_down(id);
	LL mid = Mid(tree[id].l, tree[id].r);
	if(r <= mid)updata(l,r,L(id));
	else if(mid < l)updata(l, r, R(id));
	else
	{
		updata(l,mid,L(id));
		updata(mid+1,r,R(id));
	}
	push_up(id);
}
int main(){
	LL n, m, q, i, j, u, v;
	while(~scanf("%d %d %d",&n,&m,&q)){
		for(i=1;i<=n;i++)scanf("%lld",&a[i]);
		build(1,n,1);
		while(q--){
			scanf("%d",&u);	v = u+m-1;
			printf("%lld\n",query(u,v,1));
			updata(u,v,1);
		}
	}
	return 0;
}
/*
5 5 33
2 1 3 1 4
1
1
1
1
1
1

*/

FOJ 2171 防守阵地 II 区间求和区间查询 线段树,码迷,mamicode.com

时间: 2024-10-29 02:42:30

FOJ 2171 防守阵地 II 区间求和区间查询 线段树的相关文章

FZU Problem 2171 防守阵地 II (线段树,区间更新)

 Problem 2171 防守阵地 II Accept: 143    Submit: 565Time Limit: 3000 mSec    Memory Limit : 32768 KB  Problem Description 部队中总共有N个士兵,每个士兵有各自的能力指数Xi,在一次演练中,指挥部确定了M个需要防守的地点,指挥部将选择M个士兵依次进入指定地点进行防守任务,获得的参考指数即为M个士兵的能力之和.随着时间的推移,指挥部将下达Q个指令来替换M个进行防守的士兵们,每个参加完防守

FZU_Problem 2171 防守阵地 II

http://acm.fzu.edu.cn/problem.php?pid=2171 线段树模板题,成段增减,区间求和. 思路:先查询,后更新. #include<cstdio> #define lson l , m ,rt << 1 #define rson m+1 , r , rt << 1 | 1 const int maxn = 100002; int add[maxn << 2]; int sum[maxn << 2]; void Pu

fzu 2171 防守阵地 II

首先想说的是PPT设计,现在还是有很多人只把PPT当成一个存放文字和图片的软件,说的更直接点就是当是一个可以全屏放映内容的软件.但是我想说的是PPT已经走向了设计类型的软件,当Microsoft office Powerpoint2010正式版出来的时候这种感觉更盛了.绚丽的动画和更强大的设计功能,相信微软也是以设计软件这一理念来做更深层的突破了吧.技术的不断突破也给增加了PPT设计的范围,不再是单调的报告,而开始走向了企业宣传,产品宣传,动画制作--专业的设计也不断的接合平面设计,动画设计,甚

FZU Problem 2171 防守阵地 II (裸线段树 懒惰标记)

 Problem 2171 防守阵地 II Accept: 259    Submit: 987 Time Limit: 3000 mSec    Memory Limit : 32768 KB Problem Description 部队中总共有N个士兵,每个士兵有各自的能力指数Xi,在一次演练中,指挥部确定了M个需要防守的地点,指挥部将选择M个士兵依次进入指定地点进行防守任务,获得的参考指数即为M个士兵的能力之和.随着时间的推移,指挥部将下达Q个指令来替换M个进行防守的士兵们,每个参加完防守

FZU Problem 2171 防守阵地 II (线段树区间更新模板题)

http://acm.fzu.edu.cn/problem.php?pid=2171 成段增减,区间求和.add累加更新的次数. #include <iostream> #include <cstdio> #include <cmath> #include <vector> #include <cstring> #include <string> #include <algorithm> #include <stri

FZU2171 防守阵地 II (线段树)

题目链接:http://acm.fzu.edu.cn/problem.php?pid=2170 贴个baka爷的代码留念.. 数据出的有问题,输入的字符串长度不超过1000 #include<iostream> #include<cstdio> #include<cstring> #include<string> #include<algorithm> #include<map> #include<queue> #incl

HDU 1754 - I Hate It &amp; UVA 12299 - RMQ with Shifts - [单点/区间修改、区间查询线段树]

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1754 Time Limit: 9000/3000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Problem Description 很多学校流行一种比较的习惯.老师们很喜欢询问,从某某到某某当中,分数最高的是多少.这让很多学生很反感.不管你喜不喜欢,现在需要你做的是,就是按照老师的要求,写一个程序,模拟老师的询问.当然,老师

hihoCoder 1078 区间查询线段树

题面: 对于小Ho表现出的对线段树的理解,小Hi表示挺满意的,但是满意就够了么?于是小Hi将问题改了改,又出给了小Ho: 假设货架上从左到右摆放了N种商品,并且依次标号为1到N,其中标号为i的商品的价格为Pi.小Hi的每次操作分为两种可能,第一种是修改价格--小Hi给出一段区间[L, R]和一个新的价格NewP,所有标号在这段区间中的商品的价格都变成NewP.第二种操作是询问--小Hi给出一段区间[L, R],而小Ho要做的便是计算出所有标号在这段区间中的商品的总价格,然后告诉小Hi. 那么这样

【BZOJ4653】[Noi2016]区间 双指针法+线段树

[BZOJ4653][Noi2016]区间 Description 在数轴上有 n个闭区间 [l1,r1],[l2,r2],...,[ln,rn].现在要从中选出 m 个区间,使得这 m个区间共同包含至少一个位置.换句话说,就是使得存在一个 x,使得对于每一个被选中的区间 [li,ri],都有 li≤x≤ri. 对于一个合法的选取方案,它的花费为被选中的最长区间长度减去被选中的最短区间长度.区间 [li,ri] 的长度定义为 ri−li,即等于它的右端点的值减去左端点的值. 求所有合法方案中最小