题面

loj

分析

这道题非常妙啊

对于可保留区间[l, r]

枚举右端点r

考虑l的取值范围有两重约数

记颜色i出现的最右侧位置是\(max_i\) 最左侧位置是\(min_i\)

r前最后一次出现的位置是pre[i]

1.若max[i] > r 则 l > pre[i]

2.若max[i] <= r 则 l 不能取(min[i], max[i] ]

限制一维护一下单调栈就好啦 限制二线段树维护一下

#include <cstdio>
#include <algorithm>
#include <cmath>
#include <cstring>
using namespace std;
const int N = 3e5 + 5;
const int inf = 0x3f3f3f3f;
int n, a[N], mx[N], mn[N];
long long ans;
int stk[N], top; struct Seg{
int w[N << 2]; bool flag[N << 2];
void update(int rt){
w[rt] = w[rt << 1] + w[rt << 1 | 1];
}
void pushdown(int rt, int l, int r){
if(!flag[rt]) return ;
int mid = l + ((r - l) >> 1);
w[rt << 1] = mid - l + 1;
w[rt << 1 | 1] = r - mid;
flag[rt << 1] = flag[rt << 1 | 1] = 1;
flag[rt] = 0;
}
void clr(int rt, int l, int r){
w[rt] = flag[rt] = 0;
if(l == r) return ;
int mid = l + ((r - l) >> 1);
clr(rt << 1, l, mid);
clr(rt << 1 | 1, mid + 1, r);
}
void mdf(int rt, int l, int r, int x, int y){
if(l > r) return ;
if(l >= x && r <= y){
w[rt] = r - l + 1; flag[rt] = 1;
return ;
}
pushdown(rt, l, r);
int mid = l + ((r - l) >> 1);
if(x <= mid) mdf(rt << 1, l, mid, x, y);
if(y > mid) mdf(rt << 1 | 1, mid + 1, r, x, y);
update(rt);
}
int qry(int rt, int l, int r, int x, int y){
if(l > r) return 0;
if(l >= x && r <= y) return w[rt];
pushdown(rt, l, r);
int mid = l + ((r - l) >> 1), ret = 0;
if(x <= mid) ret += qry(rt << 1, l, mid, x, y);
if(y > mid) ret += qry(rt << 1 | 1, mid + 1, r, x, y);
return ret;
}
}seg; int main(){
int T; scanf("%d", &T);
while(T--){
scanf("%d", &n); seg.clr(1, 1, n);
for(int i = 0; i <= n; ++i) mx[i] = 0, mn[i] = inf; for(int i = 1; i <= n; ++i){
scanf("%d", &a[i]);
mx[a[i]] = max(mx[a[i]], i);
mn[a[i]] = min(mn[a[i]], i);
}
ans = 0;
top = 0;
mn[0] = mx[0] = 0;
for(int r = 1; r <= n; ++r){
if(r == mx[a[r]] && r > mn[a[r]]){
seg.mdf(1, 1, n, mn[a[r]] + 1, r);
// printf("%d %d\n", mn[a[r]] + 1, r);
}
stk[++top] = r;
while(top && mx[a[stk[top]]] <= r) --top;
//这里维护颜色调了好久 蠢了蠢了 注意那个pre不是单调递增的哦 ans += (r - stk[top] - seg.qry(1, 1, n, stk[top] + 1, r));
//printf("ans = %d %d %d %d %d %d\n", ans, r, stk[top], stk[top] + 1, r, seg.qry(1, 1, n, stk[top] + 1, r));
}
printf("%lld\n", ans);
}
return 0;
}

JXOI2017颜色的更多相关文章

  1. JXOI2017颜色 解题报告

    JXOI2017颜色 首先记录每个位置上颜色在序列中上次出现的位置 开两颗线段树,第一棵维护区间最大值,实际上是维护当前必须被删去的颜色的位置的最大值,第二棵则是维护区间和 首先倒着扫一遍,对于当前颜 ...

  2. [JXOI2017]颜色 线段树求点对贡献

    [JXOI2017]颜色 题目链接 https://www.luogu.org/problemnew/show/P4065 题目描述 可怜有一个长度为 n 的正整数序列 Ai,其中相同的正整数代表着相 ...

  3. [BZOJ5011][JXOI2017]颜色

    5011: [Jx2017]颜色 Time Limit: 30 Sec  Memory Limit: 512 MBSubmit: 84  Solved: 46[Submit][Status][Disc ...

  4. 洛谷P4065 [JXOI2017]颜色(线段树)

    题意 题目链接 Sol 线段树板子题都做不出来,真是越来越菜了.. 根据题目描述,一个合法区间等价于在区间内的颜色没有在区间外出现过. 所以我们可以对于每个右端点,统计最长的左端点在哪里,刚开始以为这 ...

  5. BZOJ5011 JXOI2017颜色(主席树)

    相当于求满足在子段中出现的颜色只在该子段中出现的非空子段数量.这也就相当于其中出现的颜色最左出现的位置在左端点右侧,最右出现的位置在右端点左侧.那么若固定某个端点,仅考虑对该端点的限制,会有一段合法区 ...

  6. 【题解】JXOI2017颜色

    一眼线段树...显然,我们可以考虑最后所留下的区间,那显然这个区间中应当不能存在任何与区间外相同的颜色.这里的转化也是很常用的,我们用 \(nxt[i]\) 表示与 \(i\) 颜色相同的下一个位置在 ...

  7. [JXOI2017]颜色 线段树扫描线 + 单调栈

    ---题面--- 题解: 首先题目要求删除一些颜色,换个说法就是要求保留一些颜色,那么观察到,如果我们设ll[i]和rr[i]分别表示颜色i出现的最左边的那个点和最右边的那个点,那么题目就是在要求我们 ...

  8. BZOJ5011 & 洛谷4065 & LOJ2275:[JXOI2017]颜色——题解

    https://www.lydsy.com/JudgeOnline/problem.php?id=5011 https://www.luogu.org/problemnew/show/P4065 ht ...

  9. BZOJ5011 [JXOI2017]颜色 【线段树 + 主席树】

    题目链接 BZOJ5011 题解 一定只有我这种智障会用这么奇怪的方法做这道题.. 由题我们知道最后剩余的一定是一个区间,而且区间内的颜色不存在于区间外 所以我们的目的就是为了找到这样的区间的数量 区 ...

随机推荐

  1. Comet OJ 热身赛(E题)(处理+最短路算法)

    dijkstra 已经提交 已经通过 42.86% Total Submission:189 Total Accepted:81 题目描述 Eagle Jump公司正在开发一款新的游戏.泷本一二三作为 ...

  2. windows 环境下 eclipse + maven + tomcat 的 hello world 创建和部署

    主要记录自己一个新手用 eclipse + maven + tomcat 搭建 hello world 的过程,以及遇到的问题.讲真都是自己通过百度和谷歌一步步搭建的项目,没问过高手,也没高手可问,由 ...

  3. [2017BUAA软工助教]团队开发阶段CheckList

    alpha阶段流程与相关节点 以下流程与团队项目中个人的得分点是一一对应的,详见QA文档中"个人在团队项目的得分部分" http://www.cnblogs.com/Childis ...

  4. 异常:fatal: unable to access 'https://git.oschina.net/pcmpcs/library.git/': Could not resolve host

    git  fork项目时出现的异常. 原因: 我以前用的是ssh地址做的远程通信地址,而这次是用的是https,因为很久没用,所以忘记了以前是用ssh的了.解决方案一:复制ssh协议的地址,然后再关联 ...

  5. mysql 无法退出sql命令行编辑

    mysql 无法退出sql命令行编辑 | ANBOBhttp://www.anbob.com/archives/579.html mysql 无法退出sql命令行编辑 - 码农甲乙丙 - CSDN博客 ...

  6. jQuery操作复选框checkbox技巧总结 ---- 设置选中、取消选中、获取被选中的值、判断是否选中等

    转载:https://blog.csdn.net/chenchunlin526/article/details/77448168 jQuery操作复选框checkbox技巧总结 --- 设置选中.取消 ...

  7. day 7-19 Mysql索引原理与查询优化

    一,介绍 1.什么是索引? 一般的应用系统,读写比例在10:1左右,而且插入操作和一般的更新操作很少出现性能问题,在生产环境中,我们遇到最多的,也是最容易出问题的,还是一些复杂的查询操作,因此对查询语 ...

  8. python数据结构与算法第九天【选择排序】

    1.选择排序的原理 2.代码实现 def selection_sort(alist): n = len(alist) # 需要进行n-1次选择操作 for i in range(n-1): # 记录最 ...

  9. python 三目运算符

    格式: true_res if condition else false_res Meto 1: Meto 2: >>> x = 2 >>> x+1 if x!=1 ...

  10. 错误:org.apache.catalina.LifecycleException: Protocol handler start failed

    org.apache.catalina.LifecycleException: Protocol handler start failed at org.apache.catalina.connect ...