题目名称 | 3560. [USACO21Jan Silver]No Time to Paint |
---|---|
输入输出 | paint.in/out |
难度等级 | ★☆ |
时间限制 | 1000 ms (1 s) |
内存限制 | 256 MiB |
测试数据 | 13 |
题目来源 | 数声风笛ovo 于2021-04-03加入 |
开放分组 | 全部用户 |
提交状态 | |
分类标签 | |
分享题解 |
通过:0, 提交:2, 通过率:0% | ||||
456 | 0 | 0.000 s | 0.00 MiB | C++ |
456 | 0 | 0.006 s | 0.00 MiB | C++ |
关于 No Time to Paint 的近10条评论(全部评论) |
---|
paint.in
输出文件:paint.out
简单对比Bessie 最近收到了一套颜料,她想要给她的牧草地一端的栅栏上色。栅栏由 $N$ 个 1 米长的小段组成($1\le N\le 10^5$)。Bessie 可以使用 26 种不同的颜色,她将这些颜色由浅到深用字母 'A' 到 'Z' 标号('A' 是很浅的颜色,'Z' 是很深的颜色)。从而她可以用一个长为 $N$ 且每个字符均为字母的字符串来描述她想要给栅栏的每一小段涂上的颜色。
初始时,所有栅栏小段均未被上色。Bessie 一笔可以给任意连续若干小段涂上同一种颜色,只要她不会在较深的颜色之上涂上较浅的颜色(她只能用较深的颜色覆盖较浅的颜色)。
例如,一段长为 4 的未被涂色的栅栏可以按如下方式上色:
.... -> BBB. -> BBLL -> BQQL
由于时间紧迫,Bessie 认为她可能需要放弃为栅栏上某个连续的区间上色!现在,她正在考虑 $Q$ 个候选的区间($1\le Q\le 10^5$),每个区间用满足 $1 \leq a \leq b \leq N$ 的两个整数 $(a,b)$ 表示,为需要不上色的小段 $a \ldots b$ 的两端点位置。
对于每个候选区间,将所有区间外的栅栏小段都涂上所希望的颜色,并且区间内的栅栏小段均不涂色,最少需要涂多少笔?注意在这个过程中 Bessie 并没有真正进行任何的涂色,所以对于每个候选区间的回答是独立的。
输入的第一行包含 $N$ 和 $Q$。
下一行包含一个长为 $N$ 的字符串,表示每个栅栏小段所希望的颜色。
以下 $Q$ 行,每行包含两个空格分隔的整数 $a$ 和 $b$,表示一个不涂色的候选区间。
对于 $Q$ 个候选区间的每一个,输出一行,包含答案。
8 2 ABBAABCB 3 6 1 4
4 3
在这个样例种,除去目标颜色 $BAAB$ 所对应的区间,涂上颜色需要四笔,而除去 $ABBA$ 仅需三笔。
.... -> AA.. -> ABBB -> ABCB
测试点 1-4 满足 $N,Q\le 100$。
测试点 5-7 满足 $N,Q\le 5000$。
测试点 8-13 没有额外限制。
USACO 一月公开赛 Silver 组