1164 - 战舰萝莉

Time Limit:2s Memory Limit:256MByte

Submissions:85Solved:42

DESCRIPTION

在大战之后,法力浮·鳝AK迅速驾船驶向北海。当然他知道水之灵不可能那么容易得到,正如爱迪生曾说过:“要把BOSS打倒就要准备足够的等级。”所以鳝氪金招募了一队海盗以防战斗。
果不其然,正当鳝看见了水之灵的所在时,一大队舰娘(雾),一大队舰船突然闪现,大战一触即发。
大战前,鳝被对面的boss——北方栖姬吸引了,北方栖姬是一个可爱的小萝莉,实力却很是强劲,而鳝打算把她诱拐回家(雾),打算把她策略击破。
鳝通过提督的观察,发现北方栖姬摆出了“线段树阵形”,具体是这样的:
可以将深海栖舰的舰队看作对一个长度为n的序列建成的线段树,线段树的每个节点维护区间和,记作sumv[o]。这个值同时也是该节点的敌舰所具有的火力。同时在作战过程中,北方栖姬会不断发出区间加和区间减的指令,请注意,这些指令是以打标记的形式维护的,换而言之,某些点的sumv可能不会及时更新。
在每次敌舰队发生变化之后,鳝会问你,当前敌舰队有多少舰是“有威胁”的,我们称一艘舰是有威胁的当且仅当这艘舰的火力>k(一个给定常数)。
作为鳝船上的一名海盗,您需要回答法力浮鳝的所有询问。
下面给出敌舰队的建成,修改的具体示例代码:
http://paste.ubuntu.com/25598285/

INPUT
输入的第一行三个整数n,m,k,m表示操作次数。
接下来一行n个整数,表示线段树维护的原序列。
接下来m行,每行四个整数opt,l,r,x
如果opt=1表示区间加,反之则是区间减。表示在[l,r]加上或者减去x

OUTPUT
共m行,每行一个整数表示每次操作后的答案。

SAMPLE INPUT
8 2 20
1 2 3 4 5 6 7 8
2 1 8 100
1 1 3 20

SAMPLE OUTPUT
1
0

HINT
1 ≤ n ,m≤ 100000,序列值,k和sumv[o]始终在int范围内,可能出现负数
   A盯了一个小时后发现不会= =再看这道为什么这么水!难道第一题不是签到题- -!
代码都给出来了,xjb改一下维护一个总值k就好了,在修改函数pushdown里面维护。

 #include<bits/stdc++.h>
using namespace std;
int a[];
int sumv[];
int addv[];
int ans=,K;
struct SegTree
{
#define lson (o<<1)
#define rson (o<<1|1)
inline void pushup(int o)
{
int tmp=sumv[lson]+sumv[rson];
if(sumv[o]<=K&&tmp>K) ans++;
if(sumv[o]>K&&tmp<=K) ans--;
sumv[o]=tmp;
}
inline void pushdown(int o,int l,int r){
if(!addv[o]) {return;}
int mid=(l+r)>>,tag=addv[o];
addv[lson]+=tag;addv[rson]+=tag;
int tmp1=sumv[lson]+tag*(mid-l+);
int tmp2=sumv[rson]+tag*(r-mid);
if(sumv[lson]<=K&&tmp1>K) ans++;
if(sumv[lson]>K&&tmp1<=K) ans--;
if(sumv[rson]<=K&&tmp2>K) ans++;
if(sumv[rson]>K&&tmp2<=K) ans--;
sumv[lson]=tmp1;
sumv[rson]=tmp2;
addv[o]=;
}
inline void build(int o,int l,int r){
if(l==r){sumv[o]=a[l];if(sumv[o]>K)ans++;return;}
int mid=(l+r)>>;
build(lson,l,mid);
build(rson,mid+,r);
pushup(o);
}
inline void optadd(int o,int l,int r,int ql,int qr,int v){
if(ql<=l&&r<=qr){int tmp=v*(r-l+);
if(sumv[o]<=K&&sumv[o]+tmp>K) ans++;
if(sumv[o]>K&&sumv[o]+tmp<=K) ans--;
sumv[o]+=tmp;
addv[o]+=v;
return;
}
int mid=(l+r)>>;
pushdown(o,l,r);
if(ql<=mid)optadd(lson,l,mid,ql,qr,v);
if(qr>mid)optadd(rson,mid+,r,ql,qr,v);
pushup(o);
}
}seg;
int main()
{
int N,M;
while(scanf("%d%d%d",&N,&M,&K)!=EOF){ans=;
for(int i=;i<=N;++i) scanf("%d",a+i);
memset(addv,,sizeof(addv));
seg.build(,,N);//cout<<ans<<endl;
int opt,l,r,x;
while(M--){
scanf("%d%d%d%d",&opt,&l,&r,&x);
if(opt==) x=-x;
seg.optadd(,,N,l,r,x);
printf("%d\n",ans);
}
}
return ;
}

ll 1164 线段树的更多相关文章

  1. bzoj3932--可持久化线段树

    题目大意: 最近实验室正在为其管理的超级计算机编制一套任务管理系统,而你被安排完成其中的查询部分.超级计算机中的 任务用三元组(Si,Ei,Pi)描述,(Si,Ei,Pi)表示任务从第Si秒开始,在第 ...

  2. codevs 1082 线段树练习 3(区间维护)

    codevs 1082 线段树练习 3  时间限制: 3 s  空间限制: 128000 KB  题目等级 : 大师 Master 题目描述 Description 给你N个数,有两种操作: 1:给区 ...

  3. codevs 1576 最长上升子序列的线段树优化

    题目:codevs 1576 最长严格上升子序列 链接:http://codevs.cn/problem/1576/ 优化的地方是 1到i-1 中最大的 f[j]值,并且A[j]<A[i] .根 ...

  4. codevs 1080 线段树点修改

    先来介绍一下线段树. 线段树是一个把线段,或者说一个区间储存在二叉树中.如图所示的就是一棵线段树,它维护一个区间的和. 蓝色数字的是线段树的节点在数组中的位置,它表示的区间已经在图上标出,它的值就是这 ...

  5. codevs 1082 线段树区间求和

    codevs 1082 线段树练习3 链接:http://codevs.cn/problem/1082/ sumv是维护求和的线段树,addv是标记这歌节点所在区间还需要加上的值. 我的线段树写法在运 ...

  6. PYOJ 44. 【HNSDFZ2016 #6】可持久化线段树

    #44. [HNSDFZ2016 #6]可持久化线段树 统计 描述 提交 自定义测试 题目描述 现有一序列 AA.您需要写一棵可持久化线段树,以实现如下操作: A v p x:对于版本v的序列,给 A ...

  7. CF719E(线段树+矩阵快速幂)

    题意:给你一个数列a,a[i]表示斐波那契数列的下标为a[i],求区间对应斐波那契数列数字的和,还要求能够维护对区间内所有下标加d的操作 分析:线段树 线段树的每个节点表示(f[i],f[i-1])这 ...

  8. 【BZOJ-3779】重组病毒 LinkCutTree + 线段树 + DFS序

    3779: 重组病毒 Time Limit: 20 Sec  Memory Limit: 512 MBSubmit: 224  Solved: 95[Submit][Status][Discuss] ...

  9. 【BZOJ-3673&3674】可持久化并查集 可持久化线段树 + 并查集

    3673: 可持久化并查集 by zky Time Limit: 5 Sec  Memory Limit: 128 MBSubmit: 1878  Solved: 846[Submit][Status ...

随机推荐

  1. python函数回顾:min()

    描述 min() 方法返回给定参数的最小值,参数可以为序列. 语法 以下是 min() 方法的语法: min( x, y, z, .... ) 参数 x -- 数值表达式. y -- 数值表达式. z ...

  2. Oracle学习笔记—oracle体系架构及状态(nomount、mount和open)简介

    oracle体系架构简介 先来简要了解一下Oracle数据库体系架构以便于后面深入理解,Oracle Server主要由实例(instance)和数据库(database)组成.实例(instance ...

  3. Eclipse 变量高亮显示设置

    A:Window-> preferences->java->Editor->Mark Occurences Local variables就是变量的高亮显示

  4. input propertyChange

    結合 HTML5 標準事件 oninput 和 IE 專屬事件 onpropertychange 事件來監聽輸入框值變化. oninput 是 HTML5 的標準事件,對於檢測 textarea, i ...

  5. sorted 、 filter 、 map

    sorted   排序函数 内置函数中提供了一个通用的排序方案 ,返回一个新的列表,不会改变原数据 语法: sorted(iterable, key, reverse) key: 排序方案, sort ...

  6. iOS 视频全屏功能 学习

    项目中,也写过类似"视频全屏"的功能, 前一阵子读到今日头条 的一篇技术文章,详细介绍三种旋转方法差异优劣最终择取.文章从技术角度看写的非常好,从用户角度看,也用过多家有视频功能的 ...

  7. c# 抽象类(abstract)

    using System; using System.Collections.Generic; using System.Linq; using System.Text; //抽象类(abstract ...

  8. java实现文件的压缩和解压

    java实现文件的压缩和解压 代码压缩实现 package com.hjh.demo.zip; import java.io.BufferedInputStream; import java.io.F ...

  9. PHP 面向对象及Mediawiki 框架分析(一)

    此文是一JAVA哥大神写的,虽然他不懂PHP.我这人PHP半桶水,面向对象更是半桶水都没有,此文原本是为了让我理解MediaWiki的运行机制的,愣是用他的JAVA的面向对象知识,对Mediawiki ...

  10. 斯坦福机器学习视频笔记 Week6 关于机器学习的建议 Advice for Applying Machine Learning

    我们将学习如何系统地提升机器学习算法,告诉你学习算法何时做得不好,并描述如何'调试'你的学习算法和提高其性能的“最佳实践”.要优化机器学习算法,需要先了解可以在哪里做最大的改进. 我们将讨论如何理解具 ...