题目传送门


题目描述

(原题英文)

操作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<区间次大值,没办法了,暴力搞吧。


代码时刻

  1. #include<cstdio>
  2. #include<algorithm>
  3. #define L(x) x<<1
  4. #define R(x) x<<1|1
  5. using namespace std;
  6. int n,m;
  7. int v[1000001];
  8. long long trsum[4000001],trmax[4000001],trsec[4000001],trflg[4000001];//记得long long
  9. int trcnt[4000001];
  10. void getmin(int x,long long k)
  11. {
  12. trsum[x]-=(trmax[x]-k)*trcnt[x];//更新sum。
  13. trmax[x]=trflg[x]=k;//更新max和懒标记
  14. }
  15. void pushup(int x)//分情况pushup
  16. {
  17. if(trmax[L(x)]>trmax[R(x)])
  18. {
  19. trmax[x]=trmax[L(x)];
  20. trcnt[x]=trcnt[L(x)];
  21. trsec[x]=max(trsec[L(x)],trmax[R(x)]);
  22. }
  23. if(trmax[L(x)]<trmax[R(x)])
  24. {
  25. trmax[x]=trmax[R(x)];
  26. trcnt[x]=trcnt[R(x)];
  27. trsec[x]=max(trsec[R(x)],trmax[L(x)]);
  28. }
  29. if(trmax[L(x)]==trmax[R(x)])
  30. {
  31. trmax[x]=trmax[L(x)];
  32. trcnt[x]=trcnt[L(x)]+trcnt[R(x)];
  33. trsec[x]=max(trsec[L(x)],trsec[R(x)]);
  34. }
  35. trsum[x]=trsum[L(x)]+trsum[R(x)];
  36. }
  37. void pushdown(int x,int l,int r)
  38. {
  39. if(trflg[x]==0x7fffffff||l==r)return;
  40. if(trmax[L(x)]>trflg[x])getmin(L(x),trflg[x]);
  41. if(trmax[R(x)]>trflg[x])getmin(R(x),trflg[x]);
  42. trflg[x]=0x7fffffff;
  43. }
  44. void build(int x,int l,int r)//建树,与基本一致
  45. {
  46. trflg[x]=0x7fffffff;
  47. if(l==r)
  48. {
  49. trsum[x]=trmax[x]=v[l];
  50. trsec[x]=-0x7fffffff;
  51. trcnt[x]=1;
  52. return;
  53. }
  54. int mid=(l+r)>>1;
  55. build(L(x),l,mid);
  56. build(R(x),mid+1,r);
  57. pushup(x);
  58. }
  59. void change(int x,int l,int r,int L,int R,long long k)//更改操作
  60. {
  61. pushdown(x,l,r);
  62. if(k>=trmax[x])return;//第1种情况,直接返回
  63. if(trsec[x]<k&&k<trmax[x]&&L<=l&&r<=R){getmin(x,k);return;}//第2种情况,或者是搜到底了
  64. int mid=(l+r)>>1;
  65. if(L<=mid)change(L(x),l,mid,L,R,k);
  66. if(R>mid)change(R(x),mid+1,r,L,R,k);
  67. pushup(x);
  68. }
  69. long long askmax(int x,int l,int r,int L,int R)
  70. {
  71. if(L<=l&&r<=R)return trmax[x];
  72. pushdown(x,l,r);
  73. int mid=(l+r)>>1;
  74. long long ans=0;
  75. if(L<=mid)ans=max(ans,askmax(L(x),l,mid,L,R));
  76. if(R>mid)ans=max(ans,askmax(R(x),mid+1,r,L,R));
  77. return ans;
  78. }
  79. long long asksum(int x,int l,int r,int L,int R)
  80. {
  81. if(L<=l&&r<=R)return trsum[x];
  82. pushdown(x,l,r);
  83. int mid=(l+r)>>1;
  84. long long ans=0;
  85. if(L<=mid)ans+=asksum(L(x),l,mid,L,R);
  86. if(R>mid)ans+=asksum(R(x),mid+1,r,L,R);
  87. return ans;
  88. }
  89. int main()
  90. {
  91. int T;
  92. scanf("%d",&T);
  93. while(T--)
  94. {
  95. scanf("%d%d",&n,&m);
  96. for(int i=1;i<=n;i++)
  97. scanf("%d",&v[i]);
  98. build(1,1,n);
  99. while(m--)
  100. {
  101. int op,l,r;
  102. scanf("%d%d%d",&op,&l,&r);
  103. switch(op)
  104. {
  105. case 0:int x;scanf("%d",&x);change(1,1,n,l,r,x);break;
  106. case 1:printf("%lld\n",askmax(1,1,n,l,r));break;
  107. case 2:printf("%lld\n",asksum(1,1,n,l,r));break;
  108. }
  109. }
  110. }
  111. return 0;
  112. }

rp++

[HDU5360]:Gorgeous Sequence(小清新线段树)的更多相关文章

  1. Gorgeous Sequence 题解 (小清新线段树)

    这道题被学长称为“科幻题” 题面 事实上,并不是做法科幻,而是“为什么能这么做?”的解释非常科幻 换句话说,复杂度分析灰常诡异以至于吉如一大佬当场吃书 线段树维护的量:区间和sum,区间最大值max1 ...

  2. HDU - 5306 Gorgeous Sequence (吉司机线段树)

    题目链接 吉司机线段树裸题... #include<bits/stdc++.h> using namespace std; typedef long long ll; ,inf=0x3f3 ...

  3. [BZOJ3211]:花神游历各国(小清新线段树)

    题目传送门 题目描述: 花神喜欢步行游历各国,顺便虐爆各地竞赛.花神有一条游览路线,它是线型的,也就是说,所有游历国家呈一条线的形状排列,花神对每个国家都有一个喜欢程度(当然花神并不一定喜欢所有国家) ...

  4. [CSP-S模拟测试]:联(小清新线段树)

    题目描述 由于出题人懒所以没有背景.一个无限长的$01$序列,初始全为$0$,每次选择一个区间$[l,r]$进行操作,有三种操作:$\bullet 1\ l\ r$将$[l,r]$中所有元素变成$1$ ...

  5. 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 ...

  6. [HDU5306]Gorgeous Sequence(标记回收线段树)

    题意:维护一个序列,支持区间与一个数取min,询问区间最大,询问区间和(序列长度<=1e6) 分析: http://www.shuizilong.com/house/archives/hdu-5 ...

  7. 牛客多校第四场sequence C (线段树+单调栈)

    牛客多校第四场sequence C (线段树+单调栈) 传送门:https://ac.nowcoder.com/acm/contest/884/C 题意: 求一个$\max {1 \leq l \le ...

  8. 一篇文教你使用python Turtle库画出“精美碎花小清新风格树”快来拿代码!

    Turtle库手册可以查询查询 python图形绘制库turtle中文开发文档及示例大全,手册中现有示例,不需要自己动手就可以查看演示. 使用Turtle画树,看了一下网上的代码,基本上核心的方法是使 ...

  9. 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变 ...

随机推荐

  1. Codeforces 749C【模拟】

    FST的时候好像挂了挺多人的~ 其实思路没啥难的,就是更好地理解题意吧,1到n一直循环,直到没有人能vote,一个人能vote也能叉掉一个人,一个人被叉就不能vote,判谁赢. 其实我管vote干嘛, ...

  2. 51nod 1376【线段树维护区间最大值】

    引自:wonter巨巨的博客 定义 dp[i] := 以数字 i(不是下标 i)为结尾的最长上升长度 然后用线段树维护 dp[i]: 每个节点维护 2 个信息,一个是当前区间的最大上升长度,一个是最大 ...

  3. Java - 安装jdk并设置环境变量

    前言 双十一买了台新的笔记本,需要重新安装下Java,这里记录下安装的过程,毕竟万事开头难,就算是老手也不一定能一次就把Java安装成功. 安装jdk 作为一名Java开发,当然是要安装jdk了,如果 ...

  4. JS高级学习历程-1

    JS高级-34-昨天内容回顾     时间:2015-5-11 1.DOM获取元素节点 document.getElenmentById(id 属性值)                         ...

  5. SpringBoot | Hibernate @Transient 注解

    在默认情况下,持久化类的所有属性会自动映射到数据表的数据列.如果在实际应用中,不想持久保存某些属性,则可以考虑使用@Transient来修饰它们. 如果一个属性并非数据库表的字段映射,就务必将其标示为 ...

  6. MySQL 命令(一)

    mysql 数据库:保存有组织的数据的容器.(通常是一个文件或一组文件) 表:某种特定类型数据的结构化清单.数据库中的每个表都有一个名字,用来标识自己,此名字是唯一的 列:表中的一个字段.所有表都是由 ...

  7. 洛谷P2473||bzoj1076 [SCOI2008]奖励关

    https://www.luogu.org/problemnew/show/P2473 https://www.lydsy.com/JudgeOnline/problem.php?id=1076 不会 ...

  8. 洛谷 P4362 [NOI2002]贪吃的九头龙

    https://www.luogu.org/problemnew/show/P4362 首先有个很显然的dp:ans[i][j][k]表示i节点用j号头,i节点为根的子树中共有k个点用大头时i节点为根 ...

  9. 110 Balanced Binary Tree 平衡二叉树

    给定一个二叉树,确定它是高度平衡的.对于这个问题,一棵高度平衡二叉树的定义是:一棵二叉树中每个节点的两个子树的深度相差不会超过 1.案例 1:给出二叉树 [3,9,20,null,null,15,7] ...

  10. [已读]JavaScript模式

    主要是介绍各种继承和设计模式.第一章是讲编程规范,然后里面讲到了使用new Function替代eval