A92123.「USACO 2021.2 Platinum」No Time to Dry

提高+/省选-

通过率:0%

时间限制:2.00s

内存限制:256MB

题目描述

题目来自 USACO 2021 February Contest, Platinum Problem 1. No Time to Dry

Bessie 最近收到了一套颜料,她想要给她的牧草地一端的栅栏上色。栅栏由 NN11 米长的小段组成(1N21051\le N\le 2\cdot 10^5)。Bessie 可以使用 NN 种不同的颜色,她将这些颜色由浅到深用 11NN 标号(11 是很浅的颜色,NN 是很深的颜色)。从而她可以用一个长为 NN 的整数数组来描述她想要给栅栏的每一小段涂上的颜色。

初始时,所有栅栏小段均未被上色。Bessie 一笔可以给任意连续若干小段涂上同一种颜色,只要她不会在较深的颜色之上涂上较浅的颜色(她只能用较深的颜色覆盖较浅的颜色)。

例如,一段长为 44 的未被涂色的栅栏可以按如下方式上色:

0000 -> 1110 -> 1122 -> 1332

不幸的是,Bessie 没有足够的时间等待颜料变干。所以,Bessie 认为她可能需要放弃为栅栏上某些小段上色!现在,她正在考虑 QQ 个候选的区间(1Q21051\le Q\le 2\cdot 10^5),每个区间用满足 1abN1 \leq a \leq b \leq N 的两个整数 (a,b)(a,b) 表示,为需要上色的小段 aba \ldots b 的两端点位置。

对于每个候选区间,将所有区间内的栅栏小段都涂上所希望的颜色,并且区间外的栅栏小段均不涂色,最少需要涂多少笔?注意在这个过程中 Bessie 并没有真正进行任何的涂色,所以对于每个候选区间的回答是独立的。

输入格式

输入的第一行包含 NNQQ

下一行包含一个长为 NN 的整数数组,表示每个栅栏小段所希望的颜色。

以下 QQ 行,每行包含两个空格分隔的整数 aabb,表示一个需要涂色的候选区间。

输出格式

对于 QQ 个候选区间的每一个,输出一行,包含答案。

输入输出样例

  • 输入#1

    8 4
    1 2 2 1 1 2 3 2
    4 6
    3 6
    1 6
    5 8

    输出#1

    2
    3
    3
    3

说明/提示

  • 测试点 121\sim 2 满足 N,Q100N,Q\le 100
  • 测试点 353\sim 5 满足 N,Q5000N,Q\le 5000
  • 测试点 6106\sim 10 中,输入数组不包含大于 1010 的数。
  • 测试点 112011\sim 20 没有额外限制。
首页