[HDU5360]:Gorgeous Sequence(小清新线段树)
题目传送门
题目描述
(原题英文)
操作0:输入l,r,t,线段树区间与t取min。
操作1:输入l,r,区间取最大值。
操作2:输入l,r,区间求和。
输入格式
第一行一个整数T,表示数据组数;
对于每组数据,第一行两个整数n,m;
第二行n个整数,分别表示每个点的初始值。
第三行到第m+2行,一开始一个整数表示操作几,如题。
输出格式
每一个询问操作,对应相应输出。
样例
样例输入:
1
5 5
1 2 3 4 5
1 1 5
2 1 5
0 3 5 3
1 1 5
2 1 5
样例输出:
5
15
3
12
数据范围与提示
1≤n,m≤106,0≤ai,t≤231
题解
很显然区间取最大值和区间求和操作都是线段树基本操作,在此就不做过多赘述。
但是区间与t取最小值很难处理,不用懒标志之类的东西会被卡成n2,那么我们需要考虑如何搞一个想懒标记一样的东西。
那么考虑维护这三个值:
1.区间最大值。
2.区间次大值。
3.最大值的个数。
然后我们在与t取min的时候分为一下三种情况:
1.t≥区间最大值,直接return。
2.区间次大值≤t<区间最大值,这时候我们可以直接更新区间最大值,区间和,懒标记,然后return即可。
3.t<区间次大值,没办法了,暴力搞吧。
代码时刻
#include<cstdio>
#include<algorithm>
#define L(x) x<<1
#define R(x) x<<1|1
using namespace std;
int n,m;
int v[1000001];
long long trsum[4000001],trmax[4000001],trsec[4000001],trflg[4000001];//记得long long
int trcnt[4000001];
void getmin(int x,long long k)
{
trsum[x]-=(trmax[x]-k)*trcnt[x];//更新sum。
trmax[x]=trflg[x]=k;//更新max和懒标记
}
void pushup(int x)//分情况pushup
{
if(trmax[L(x)]>trmax[R(x)])
{
trmax[x]=trmax[L(x)];
trcnt[x]=trcnt[L(x)];
trsec[x]=max(trsec[L(x)],trmax[R(x)]);
}
if(trmax[L(x)]<trmax[R(x)])
{
trmax[x]=trmax[R(x)];
trcnt[x]=trcnt[R(x)];
trsec[x]=max(trsec[R(x)],trmax[L(x)]);
}
if(trmax[L(x)]==trmax[R(x)])
{
trmax[x]=trmax[L(x)];
trcnt[x]=trcnt[L(x)]+trcnt[R(x)];
trsec[x]=max(trsec[L(x)],trsec[R(x)]);
}
trsum[x]=trsum[L(x)]+trsum[R(x)];
}
void pushdown(int x,int l,int r)
{
if(trflg[x]==0x7fffffff||l==r)return;
if(trmax[L(x)]>trflg[x])getmin(L(x),trflg[x]);
if(trmax[R(x)]>trflg[x])getmin(R(x),trflg[x]);
trflg[x]=0x7fffffff;
}
void build(int x,int l,int r)//建树,与基本一致
{
trflg[x]=0x7fffffff;
if(l==r)
{
trsum[x]=trmax[x]=v[l];
trsec[x]=-0x7fffffff;
trcnt[x]=1;
return;
}
int mid=(l+r)>>1;
build(L(x),l,mid);
build(R(x),mid+1,r);
pushup(x);
}
void change(int x,int l,int r,int L,int R,long long k)//更改操作
{
pushdown(x,l,r);
if(k>=trmax[x])return;//第1种情况,直接返回
if(trsec[x]<k&&k<trmax[x]&&L<=l&&r<=R){getmin(x,k);return;}//第2种情况,或者是搜到底了
int mid=(l+r)>>1;
if(L<=mid)change(L(x),l,mid,L,R,k);
if(R>mid)change(R(x),mid+1,r,L,R,k);
pushup(x);
}
long long askmax(int x,int l,int r,int L,int R)
{
if(L<=l&&r<=R)return trmax[x];
pushdown(x,l,r);
int mid=(l+r)>>1;
long long ans=0;
if(L<=mid)ans=max(ans,askmax(L(x),l,mid,L,R));
if(R>mid)ans=max(ans,askmax(R(x),mid+1,r,L,R));
return ans;
}
long long asksum(int x,int l,int r,int L,int R)
{
if(L<=l&&r<=R)return trsum[x];
pushdown(x,l,r);
int mid=(l+r)>>1;
long long ans=0;
if(L<=mid)ans+=asksum(L(x),l,mid,L,R);
if(R>mid)ans+=asksum(R(x),mid+1,r,L,R);
return ans;
}
int main()
{
int T;
scanf("%d",&T);
while(T--)
{
scanf("%d%d",&n,&m);
for(int i=1;i<=n;i++)
scanf("%d",&v[i]);
build(1,1,n);
while(m--)
{
int op,l,r;
scanf("%d%d%d",&op,&l,&r);
switch(op)
{
case 0:int x;scanf("%d",&x);change(1,1,n,l,r,x);break;
case 1:printf("%lld\n",askmax(1,1,n,l,r));break;
case 2:printf("%lld\n",asksum(1,1,n,l,r));break;
}
}
}
return 0;
}
rp++
[HDU5360]:Gorgeous Sequence(小清新线段树)的更多相关文章
- Gorgeous Sequence 题解 (小清新线段树)
		
这道题被学长称为“科幻题” 题面 事实上,并不是做法科幻,而是“为什么能这么做?”的解释非常科幻 换句话说,复杂度分析灰常诡异以至于吉如一大佬当场吃书 线段树维护的量:区间和sum,区间最大值max1 ...
 - HDU - 5306 Gorgeous Sequence (吉司机线段树)
		
题目链接 吉司机线段树裸题... #include<bits/stdc++.h> using namespace std; typedef long long ll; ,inf=0x3f3 ...
 - [BZOJ3211]:花神游历各国(小清新线段树)
		
题目传送门 题目描述: 花神喜欢步行游历各国,顺便虐爆各地竞赛.花神有一条游览路线,它是线型的,也就是说,所有游历国家呈一条线的形状排列,花神对每个国家都有一个喜欢程度(当然花神并不一定喜欢所有国家) ...
 - [CSP-S模拟测试]:联(小清新线段树)
		
题目描述 由于出题人懒所以没有背景.一个无限长的$01$序列,初始全为$0$,每次选择一个区间$[l,r]$进行操作,有三种操作:$\bullet 1\ l\ r$将$[l,r]$中所有元素变成$1$ ...
 - HDU - 5306: Gorgeous Sequence (势能线段树)
		
There is a sequence aa of length nn. We use aiai to denote the ii-th element in this sequence. You s ...
 - [HDU5306]Gorgeous Sequence(标记回收线段树)
		
题意:维护一个序列,支持区间与一个数取min,询问区间最大,询问区间和(序列长度<=1e6) 分析: http://www.shuizilong.com/house/archives/hdu-5 ...
 - 牛客多校第四场sequence C (线段树+单调栈)
		
牛客多校第四场sequence C (线段树+单调栈) 传送门:https://ac.nowcoder.com/acm/contest/884/C 题意: 求一个$\max {1 \leq l \le ...
 - 一篇文教你使用python Turtle库画出“精美碎花小清新风格树”快来拿代码!
		
Turtle库手册可以查询查询 python图形绘制库turtle中文开发文档及示例大全,手册中现有示例,不需要自己动手就可以查看演示. 使用Turtle画树,看了一下网上的代码,基本上核心的方法是使 ...
 - HDU 3397 Sequence operation(线段树)
		
HDU 3397 Sequence operation 题目链接 题意:给定一个01序列,有5种操作 0 a b [a.b]区间置为0 1 a b [a,b]区间置为1 2 a b [a,b]区间0变 ...
 
随机推荐
- 【废弃】JavaScript 删除部分
			
创建: 2019/02/26 添加: 2019/02/06 添加Object部分 添加: 2019/03/09 添加Function部分 毕竟自己曾经写的,彻底删得不留痕迹还是舍不得的. 但是的确已经 ...
 - HTML基本标签元素
			
HTML: 超文本标记语言(HyperText Mark-up Language ) 1.作用:写网页结构 2.HTML不区分大小写,建议小写 3.文件后缀 .html 或者 .ht ...
 - POJ3697【BFS】
			
题意: n个点的完全图,删掉m条边以后,求与1联通的点的个数. 思路: 直接判断 遍历图,n(n+1)/2=5e7 复杂度n^2......,哦,这样也行... //#include<bits/ ...
 - CodeForces 644B【模拟】
			
题意: 查询数 和 最大的队列容量+1: 按时间顺序 ti代表,第i个出线的时间: di代表,第i个需要处理的时间: 对于第i个输出他所需要的时间完成,或者拒绝进入输出-1: 思路: 真是MDZZ了, ...
 - IT行业技术及程序员相关网站荟萃
			
最近我花了一些时间收集了一些与自己工作相关的常用的网址,由于时间关系,暂时只是收集了这么多,以后有时间再随时添加. 1.程序员网址导航pg265 http://www.pg265.com/TNT程序网 ...
 - poj3276 Face The Right Way
			
Face The Right Way POJ - 3276 题目大意: n头牛排成一列,每头牛向前或向后,为了让所有牛都面向前方,设定一个k值,每操作一次恰好使k头连续的牛转向,求最少的操作次数m和对 ...
 - bat脚本启动Burp
			
我的burp点击之后并不会直接打开,需要用命令启动,所以在网上找了一下快捷启动的方法. ①新建一个文本文档,输入start javaw -jar “burp路径”, ②另存为***.bat,文件类型选 ...
 - python入门之前面内容拾遗
			
int n1 = 123 #根据int类,创建了一个对象 n2 = int(123) #根据int类,创建了一个对象,这里实际上调用了int类里的内置函数__int__(x,2),其中x为定义的对象, ...
 - python+selenium 页面中存在选项卡时,获取页面内容的小技巧
			
最近用selenium读取页面内容时,遇到包含选项卡的页面,由于选项卡多由js加载其中的内容,所以在网址打开时只能获取到默认显示的选项卡中的内容,而tab2.tab3等等都需要傻傻的点击一下才会获取到 ...
 - nodejs学习(3) express+socket.io
			
//node var express=require('express'); var app = express(); var server = require('http').createServe ...