#P1276. 起止位置
起止位置
题目描述
有 n 位同学按照年龄从小到大排好队。
王老师想要查询,年龄为x的同学,在队伍中首次出现的位置和最后一次出现的位置;如果队伍中不存在年龄为 x 的同学,请输出 -1 。
由于人数太多,一个一个数,太慢啦,请你编程求解。
请注意:本题中王老师查询年龄 x 出现的起止位置,并不是查询了 1 次,而是查询了 q 次。
输入格式
第一行包含整数 n 和 q ,表示队伍中的总人数和询问个数。
第二行包含 n 个整数(均在 1~10000 范围内),表示队伍中每个人的年龄。
接下来 q 行,每行包含一个整数 x ,表示一次询问的值。
数据范围
1 ≤ n ≤ 100000
1 ≤ q ≤ 10000
1 ≤ x ≤ 10000
输出格式
共 q 行,每行包含两个整数,表示所求年龄在队伍中的起始位置和终止位置。
如果数组中不存在该元素,则返回"-1 -1"。
样例
6 4
1 2 2 2 3 3
2
1
3
8
2 4
1 1
5 6
-1 -1
样例解释
有 6 位同学的年龄为: 1 2 2 2 3 3 ,王老师查询了 4 个年龄,分别是 2 1 3 8:
年龄为2的同学首次和最后一次出现的位置分别是:2 4;
年龄为1的同学首次和最后一次出现的位置分别是:1 1;
年龄为3的同学首次和最后一次出现的位置分别是:5 6;
年龄为8的同学首次和最后一次出现的位置分别是:-1 -1;