\(\text{Solution}\)

一个点可与另一个颜色相同点同时涂色当且仅当两点间颜色都大于等于这两点

那么我们可以预处理一个点向左向右最远能到的位置,记为 \(l_i,r_i)\)

当 \(l_i = l_j \text{ and }r_i = r_j\) 时,\((i,j)\) 就可以同时涂色

我们认为他们是相同

预处理 \(l_i,r_i\) 正反两次单调栈即可

那么一个区间的答案就是 \(l_i,r_i\) 不相同的个数

将 \(l_i,r_i\) 排序后重新编号,主席树维护即可

这就相当于区间数颜色

注:空间开到 \(2 \log n\) 倍

纪念考场暴切此题但空间开小白丢 \(5pts\)

#include <cstdio>
#include <algorithm>
#include <cstring>
#define re register
using namespace std; const int N = 2e5 + 5;
int n, q, stk[N], top;
struct node{int v, l, r, id;}a[N]; inline void read(int &x)
{
x = 0; char ch = getchar();
while (ch < '0' || ch > '9') ch = getchar();
while (ch >= '0' && ch <= '9') x = x * 10 + ch - '0', ch = getchar();
} inline bool cmp1(node a, node b){return (a.l < b.l ? 1 : (a.l == b.l ? a.r < b.r : 0));}
inline bool cmp2(node a, node b){return a.id < b.id;} int size, lst[N], rt[N];
struct ChairManTree{int ls, rs, s;}seg[N * 40];
inline void update(int &p, int pre, int l, int r, int x, int v)
{
p = ++size;
seg[p] = seg[pre], seg[p].s = seg[pre].s + v;
if (l == r) return;
int mid = (l + r) >> 1;
if (x <= mid) update(seg[p].ls, seg[pre].ls, l, mid, x, v);
else update(seg[p].rs, seg[pre].rs, mid + 1, r, x, v);
}
inline int query(int p, int l, int r, int x)
{
if (l == r) return seg[p].s;
int mid = (l + r) >> 1;
if (x <= mid) return query(seg[p].ls, l, mid, x) + seg[seg[p].rs].s;
return query(seg[p].rs, mid + 1, r, x);
} int main()
{
read(n), read(q);
for(re int i = 1; i <= n; i++) read(a[i].v), a[i].l = a[i].r = a[i].id = i;
for(re int i = 1; i <= n; i++)
{
while (top && a[stk[top]].v >= a[i].v) a[i].l = a[stk[top]].l, --top;
if (!top) a[i].l = 1;
stk[++top] = i;
}
top = 0;
for(re int i = n; i; i--)
{
while (top && a[stk[top]].v >= a[i].v) a[i].r = a[stk[top]].r, --top;
if (!top) a[i].r = n;
stk[++top] = i;
} sort(a + 1, a + n + 1, cmp1);
a[1].v = top = 1;
for(re int i = 2; i <= n; i++)
if (a[i].l == a[i - 1].l && a[i].r == a[i - 1].r) a[i].v = top;
else a[i].v = ++top;
sort(a + 1, a + n + 1, cmp2); memset(lst , 255 , sizeof lst);
for(re int i = 1, pre; i <= n; i++)
{
if (lst[a[i].v] == -1) update(rt[i], rt[i - 1], 1, n, i, 1);
else update(pre, rt[i - 1], 1, n, lst[a[i].v], -1), update(rt[i], pre, 1, n, i, 1);
lst[a[i].v] = i;
}
for(re int i = 1, l, r; i <= q; i++)
read(l), read(r), printf("%d\n", query(rt[r], 1, n, l));
}

【USACO 2021 February Contest, Platinum】Problem 1 No Time to Dry的更多相关文章

  1. 孤独的照片【USACO 2021 December Contest Bronze】

    孤独的照片 Farmer John 最近购入了 \(N\) 头新的奶牛,每头奶牛的品种是更赛牛(Guernsey)或荷斯坦牛(Holstein)之一. 奶牛目前排成一排,Farmer John 想要为 ...

  2. 洛谷 P2812 校园网络【[USACO]Network of Schools加强版】 解题报告

    P2812 校园网络[[USACO]Network of Schools加强版] 题目背景 浙江省的几所OI强校的神犇发明了一种人工智能,可以AC任何题目,所以他们决定建立一个网络来共享这个软件.但是 ...

  3. 【USACO 2019 Feburary Contest】Gold

    模拟二月金组,三个半小时AK. USACO 2019 Feburary Contest, Gold T1 题意:给定一棵树,每个点有点权,每次可以进行以下操作之一: 更改一个点的点权 求某条路径上的点 ...

  4. USACO 2015 December Contest, Platinum Problem Max Flow【树链剖分】

    题意比较难理解,就是给你n个点的树,然后给你m个修改操作,每一次修改包括一个点对(x, y),意味着将x到y所有的点权值加一,最后问你整个树上的点权最大是多少. 比较裸的树链剖分了,感谢Haild的讲 ...

  5. 【 2013 Multi-University Training Contest 3 】

    HDU 4622 Reincarnation 枚举字符串的起点,构造后缀自动机,每次插入一个字符,就能统计得到当前不同字串的个数,预处理出所有的询问. #include<cstdio> # ...

  6. 【贪心+中位数】【新生赛3 1007题】 Problem G (K)

    Problem G Time Limit : 4000/2000ms (Java/Other)   Memory Limit : 32768/32768K (Java/Other) Total Sub ...

  7. USACO 2016 February Contest, Gold解题报告

    1.Circular Barn   http://www.usaco.org/index.php?page=viewproblem2&cpid=621 贪心 #include <cstd ...

  8. 【 2013 Multi-University Training Contest 8 】

    HDU 4678 Mine 对于每个空白区域,求SG值. 最后异或起来等于0,先手必败. #pragma comment(linker,"/STACK:102400000,102400000 ...

  9. 【 2013 Multi-University Training Contest 7 】

    HDU 4666 Hyperspace 曼哈顿距离:|x1-x2|+|y1-y2|. 最远曼哈顿距离,枚举x1与x2的关系以及y1与y2的关系,取最大值就是答案. #include<cstdio ...

  10. 【 2013 Multi-University Training Contest 6 】

    HDU 4655 Cut Pieces 假设n个数构成的总数都分成了n段,总数是n*a1*a2*...*an.但是答案显然不会那么多. 对于相邻的两个ai,ai+1,如果选择相同的颜色,那么就减少了a ...

随机推荐

  1. 4.2:Scrapy爬虫

    使用Scrapy框架对网站的内容进行爬取 在桌面处打开终端,并在终端中输入: scrapy startproject bitNews cd bitNews/bitNews 修改items文件的内容,输 ...

  2. 100IT 名企 java 面试必考面试题

    一.Java基础(2/133) 二.Java代码报错(52/133) 三.算法与编程(55/133) 四.html&JavaScript&ajax部分 五.Java Web部分 六.数 ...

  3. TransmittableThreadLocal和@Async优雅的记录操作日志

    此文主要讲解: 如何实现操作记录 如何将TransmittableThreadLocal和@Async搭配使用 TransmittableThreadLocal阿里的一个开源组件,为了在使用线程池等会 ...

  4. Python 缩进语法的起源:上世纪 60-70 年代的大胆创意!

    上个月,Python 之父 Guido van Rossum 在推特上转发了一篇文章<The Origins of Python>,引起了我的强烈兴趣. 众所周知,Guido 在 1989 ...

  5. GO语言基础 为什么我要学习Golang以及GO语言入门普及

    作为网络安全初学者,会遇到采用Go语言开发的恶意样本.因此从今天开始从零讲解Golang编程语言,一方面是督促自己不断前行且学习新知识:另一方面是分享与读者,希望大家一起进步.这系列文章入门部分将参考 ...

  6. Nmap扫描参数

    执行Nmap/nmap --help查看帮助文档,将显示Namp的用法及其功能Nmap的相关参数的含义与用法:扫描目标时用到的参数:-iL:从文件中导入目标主机或目标网段-iR:随意选择目标主机--e ...

  7. uniapp 微信小程序-点击图片放大图片

    <view class="pij-cont-imgbox" v-if='item.images.length>0'> <view class="p ...

  8. 学习ASP.NET Core Blazor编程系列十八——文件上传(中)

    学习ASP.NET Core Blazor编程系列文章之目录 学习ASP.NET Core Blazor编程系列一--综述 学习ASP.NET Core Blazor编程系列二--第一个Blazor应 ...

  9. 初探富文本之OT协同算法

    初探富文本之OT协同算法 OT的英文全称是Operational Transformation,是一种处理协同编辑的算法.当前OT算法用的比较多的地方就是富文本编辑器领域了,常用于作为实现文档协同的底 ...

  10. 问一个 Windows 窗口的 Capture 问题

    好久没写了,上来先问一个问题...羞射... 有 A.B 两个窗口,A 是 B 的 Owner,B 不激活不抢焦点.在 B 的 WM_LBUTTONDOWN 的时候,设置 A 窗口为 Capture: ...