题目名称 4187. [GESP202403 八级] 接竹竿
输入输出 bamboo.in/out
难度等级 ★★
时间限制 1000 ms (1 s)
内存限制 256 MiB
测试数据 10
题目来源 Gravatarsyzhaoss 于2025-10-28加入
开放分组 全部用户
提交状态
分类标签
倍增法
分享题解
通过:7, 提交:17, 通过率:41.18%
Gravatarsyzhaoss 100 0.556 s 4.90 MiB C++
Gravatar梦那边的美好ME 100 1.173 s 3.74 MiB C++
Gravatar我常常追忆未来 100 1.197 s 3.81 MiB C++
Gravatar淮淮清子 100 1.277 s 3.84 MiB C++
Gravatar淮淮清子 100 1.296 s 3.79 MiB C++
Gravatar陆晨洗 100 1.596 s 4.91 MiB C++
Gravatar梦那边的美好TT 100 2.014 s 3.83 MiB C++
Gravatar我常常追忆未来 70 6.999 s 4.06 MiB C++
Gravatar我常常追忆未来 70 7.019 s 4.10 MiB C++
Gravatar我常常追忆未来 70 7.041 s 4.04 MiB C++
本题关联比赛
NOIP2025模拟赛1
关于 接竹竿 的近10条评论(全部评论)

4187. [GESP202403 八级] 接竹竿

★★   输入文件:bamboo.in   输出文件:bamboo.out   简单对比
时间限制:1 s   内存限制:256 MiB

【题目描述】

小杨同学想用卡牌玩一种叫做“接竹竿”的游戏。

游戏规则是:每张牌上有一个点数 $v$,将给定的牌依次放入一列牌的末端。若放入之前这列牌中已有与这张牌点数相同的牌,则小杨同学会将这张牌和点数相同的牌之间的所有牌全部取出队列(包括这两张牌本身)。

小杨同学现在有一个长度为 $n$ 的卡牌序列 $A$,其中每张牌的点数为 $A_i$($1\le i\le n$)。小杨同学有 $q$ 次询问。第 $i$ 次($1\le i\le q$)询问时,小杨同学会给出 $l_i,r_i$ 小杨同学想知道如果用下标在 $[l_i,r_i]$ 的所有卡牌按照下标顺序玩“接竹竿”的游戏,最后队列中剩余的牌数。

【输入格式】

一行包含一个正整数 $T$,表示测试数据组数。

对于每组测试数据,第一行包含一个正整数 $n$,表示卡牌序列 $A$ 的长度。

第二行包含 $n$ 个正整数 $A_1,A_2,\dots,A_n$,表示卡牌的点数 $A$。

第三行包含一个正整数 $q$,表示询问次数。

接下来 $q$ 行,每行两个正整数 $l_i,r_i$ 表示一组询问。

【输出格式】

对于每组数据,输出 $q$ 行。第 $i$ 行($1\le i\le q$)输出一个非负整数,表示第 $i$ 次询问的答案。

【样例输入】

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

【样例输出】

1
1
0
2

【样例说明】

对于第一次询问,小杨同学会按照 $1,2,2$ 的顺序放置卡牌,在放置最后一张卡牌时,两张点数为 $2$ 的卡牌会被收走,因此最后队列中只剩余一张点数为 $1$ 的卡牌。

对于第二次询问,队列变化情况为:

$\{\}\to\{1\}\to\{1,2\}\to\{1,2,2\}\to\{1\}\to\{1,3\}\to\{1,3,1\}\to\{\}\to\{3\}$。因此最后队列中只剩余一张点数为 $3$ 的卡牌。

【样例下载】

样例下载

【数据规模与约定】

对于$30\%$的数据,有$1\leq n,q\leq 100$。

对于另外$30\%$的数据,有$1\leq n,q\leq 1.5\times 10^4$,所有询问的右端点等于$n$。

对于$100\%$的数据,保证有 $1\le T\le 5$,$1\le n\le 1.5\times 10^4$,$1\le q\le 1.5\times 10^4$,$1\le A_i\le 13$。