题意:http://uoj.ac/problem/169

sol  :线段树..........蜜汁TLE了一个点,不管了.....

   代码抄snowMyDream的,orz...........

   线段树需要维护以下奇奇怪怪的一堆东西......

     区间最小值及其lazy标记

     区间严格次小值及其lazy标记

     最小值、严格次小值lazy标记的前缀和,历史最小值

   dalao的博客说了一堆势能之类的东西我也没看懂.......我是看代码才明白的QAQ

#include<iostream>
#include<algorithm>
#include<cstdio>
#include<cstring>
#define inf 2147483647
using namespace std;
const int Mx=;
int n,m,root,a[Mx],l[Mx],r[Mx];
int tot,lson[Mx],rson[Mx],val[Mx],lazy[Mx],sum[Mx],Mnhis[Mx];
int Val[Mx],Lazy[Mx],Sum[Mx];//次小值 inline int read()
{
int x=,f=;char ch=getchar();
while(ch<''||ch>'') { if(ch=='-') f=-; ch=getchar(); }
while(ch>=''&&ch<='') { x=x*+ch-''; ch=getchar(); }
return x*f;
} void pushup(int x)
{
int L=lson[x],R=rson[x];
Mnhis[x]=min(Mnhis[L],Mnhis[R]);
val[x]=min(val[L],val[R]);
if(val[L]!=val[R])
Val[x]=min(max(val[L],val[R]),min(Val[L],Val[R]));
else
Val[x]=min(Val[L],Val[R]);
} void build(int &x,int L,int R)
{
x=++tot,l[x]=L,r[x]=R;
if(L==R)
val[x]=a[L],Val[x]=inf,Mnhis[x]=val[x];
else
{
int mid=(L+R)/;
build(lson[x],L,mid);
build(rson[x],mid+,R);
pushup(x);
}
} void Push(int x,int i,bool flag)
{
int la=lazy[i],La=Lazy[i],su=sum[i],Su=Sum[i];
if(!flag) la=La,su=Su;
Mnhis[x]=min(Mnhis[x],val[x]+su);
val[x]+=la; if(Val[x]!=inf) Val[x]+=La;
sum[x]=min(sum[x],lazy[x]+su),Sum[x]=min(Sum[x],Lazy[x]+Su);
lazy[x]+=la,Lazy[x]+=La;
} void pushdown(int x)
{
if(!lazy[x]&&!Lazy[x]&&sum[x]>=&&Sum[x]>=) return ;
int L=lson[x],R=rson[x];
if(val[L]==val[R]) Push(L,x,),Push(R,x,);
if(val[L]<val[R]) Push(L,x,),Push(R,x,);
if(val[L]>val[R]) Push(L,x,),Push(R,x,);
lazy[x]=Lazy[x]=sum[x]=Sum[x]=;
} void Add(int x,int ll,int rr,int c)
{
int L=l[x],R=r[x];
if(L>rr||R<ll) return ;
if(ll<=L&&rr>=R)
{
val[x]+=c; if(Val[x]!=inf) Val[x]+=c;
lazy[x]+=c,Lazy[x]+=c;
sum[x]=min(sum[x],lazy[x]),Sum[x]=min(Sum[x],Lazy[x]);
Mnhis[x]=min(Mnhis[x],val[x]);
}
else
{
pushdown(x);
Add(lson[x],ll,rr,c);
Add(rson[x],ll,rr,c);
pushup(x);
}
} void Max(int x,int ll,int rr,int c)
{
int L=l[x],R=r[x];
if(L>rr||R<ll) return ;
if(ll<=L&&rr>=R&&Val[x]>c)
{
if(val[x]<c)
{
lazy[x]+=c-val[x];
val[x]=c;
}
}
else
{
pushdown(x);
Max(lson[x],ll,rr,c);
Max(rson[x],ll,rr,c);
pushup(x);
}
} int Query(int x,int ll,int rr,bool flag)
{
int L=l[x],R=r[x];
if(L>rr||R<ll) return inf;
if(ll<=L&&rr>=R)
{
if(flag) return Mnhis[x];
else return val[x];
}
else
{
pushdown(x);
int ans=min(Query(lson[x],ll,rr,flag),Query(rson[x],ll,rr,flag));
pushup(x);
return ans;
}
} int main()
{
scanf("%d%d",&n,&m);
for(int i=;i<=n;i++) a[i]=read();;
build(root,,n);
for(int i=,num,x,y,z;i<=m;i++)
{
scanf("%d%d%d",&num,&x,&y);
if(num==) z=read(),Add(root,x,y,z);
if(num==) z=read(),Max(root,x,y,z);
if(num==) printf("%d\n",Query(root,x,y,));
if(num==) printf("%d\n",Query(root,x,y,));
}
return ;
}

uoj169:元旦老人与数列的更多相关文章

  1. UOJ169. 【UR #11】元旦老人与数列

    传送门 考虑用 \(segment~tree~beats\) 那一套理论,维护区间最小值 \(mn\) 和严格次小值 \(se\) 那么可以直接 \(mlog^2n\) 维护前三个操作 考虑维护历史最 ...

  2. 2018.07.28 uoj#169. 【UR #11】元旦老人与数列(线段树)

    传送门 线段树好题. 维护区间加,区间取最大值,维护区间最小值,历史区间最小值. 同样先考虑不用维护历史区间最小值的情况,这个可以参考这道题的解法,维护区间最小和次小值可以解决前两个操作,然后使用历史 ...

  3. 【UOJ#169】元旦老人与数列

    论文题. 考虑到这题的维护和区间操作是反向的,也就是说无法像V那题快速的合并标记. 我们知道,一个区间的最小值和其他值是可以分开来维护的,因为如果一个区间被整体覆盖,那么最小值始终是最小值. 对于被覆 ...

  4. UR11 A.元旦老人与汉诺塔

    题目:http://uoj.ac/contest/23/problem/167 如果我们拿个map来存状态的话.设当前状态是v,下一个状态是s.有f[i+1][s]+=f[i][v]. 初始f[0][ ...

  5. [UOJ #167]【UR #11】元旦老人与汉诺塔

    题目大意:给你一个有$n$个盘子的汉诺塔状态$S$,问有多少种不同的操作方法,使得可以在$m$步以内到达状态$T$.$n,m\leqslant100$ 题解:首先可以知道的是,一个状态最多可以转移到其 ...

  6. 网路流 uoj 168 元旦老人与丛林

    http://uoj.ac/problem/168 没想到是网络流 官方题解地址 http://jiry-2.blog.uoj.ac/blog/1115 subtask2告诉我们度数为012的点对答案 ...

  7. uoj167 元旦老人与汉诺塔(记忆化搜索)

    QwQ太懒了,题目直接复制uoj的了 QwQ这个题可以说是十分玄学的一道题了 首先可以暴搜,就是\(dfs\)然后模拟每个过程是哪个柱子向哪个柱子移动 不多解释了,不过实现起来还是有一点点难度的 直接 ...

  8. 2018.07.29~30 uoj#170. Picks loves segment tree VIII(线段树)

    传送门 线段树好题. 维护区间取两种最值,区间加,求区间两种历史最值,区间最小值. 自己的写法调了一个晚上+一个上午+一个下午+一个晚上并没有调出来,90" role="prese ...

  9. C#求斐波那契数列第30项的值(递归和非递归)

    using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.T ...

随机推荐

  1. 路由器基础配置之rip

    我们将以上面的拓扑图进行实验,用rip协议来进行实验,目的是实现三台不同网段的pc机之间实现互相通信 首先为pc机配置好ip地址和网关,配置完IP地址后在配置路由器 router1: enable 进 ...

  2. php学习【2】

    1:运算符 <?php $x=1; echo 1+1;//算术运算符 echo $x+=5;//赋值运算符 echo "<br/>"; echo $x++; ec ...

  3. 10 ajax

    Ajax准备知识:json 什么是json? 定义: JSON(JavaScript Object Notation, JS 对象标记) 是一种轻量级的数据交换格式.它基于 ECMAScript (w ...

  4. JAVA API访问Hbase org.apache.hadoop.hbase.client.RetriesExhaustedException: Failed after attempts=32

    Java使用API访问Hbase报错: 我的hbase主节点是spark1   java代码访问hbase的时候写的是ip 结果运行程序报错 不能够识别主机名 修改主机名     修改主机hosts文 ...

  5. copyEvens

    public int[] copyEvens(int[] nums, int count) { int newIndex=0; int i=0; int newArray[] = new int[co ...

  6. 天性 & 如水一般,遇强则强 —— 梦想、行为、性格

    开篇声明,我博客中“小心情”这一系列,全都是日记啊随笔啊什么乱七八糟的.如果一不小心点进来了,不妨直接关掉.我自己曾经写过一段时间的日记,常常翻看,毫无疑问我的文笔是很差的,而且心情也是瞬息万变的.因 ...

  7. 风格指南--C++

    0.避免多重包含是学编程时基本的要求; 1. 前置声明是为了降低编译依赖,防止修改一个头文件引发多米诺效应; 2. 内联函数的合理使用可提高代码执行效率; 3. ‐inl.h 可提高代码可读性 (一般 ...

  8. github+git提交 基础用法

    git版本管理基本用法: 安装就不用说了 随便一搜 安装完 妥妥的.下边说的是在github从新建一个项目开始: 1.首先打开自己的github地址,如下图所示 点加号 选 New repositor ...

  9. 用Chrome浏览器,学会这27个超好用功能

    一些非常有用的隐藏捷径 1. 想要在后台打开一个新的标签页而不离开现有的页面,这样就不会打断目前的工作了?按住 Ctrl 键或 Cmd 并点击它.如果你要在一个全新的窗口中打开一个链接,那就按 Shi ...

  10. 抓包工具 - Fiddler - (一)

    <转载于 miantest> Fiddler基础知识 Fiddler是强大的抓包工具,它的原理是以web代理服务器的形式进行工作的,使用的代理地址是:127.0.0.1,端口默认为8888 ...