BZOJ#1901 Dynamic Rankings
Description
给定一个含有n个数的序列a[1],a[2],a[3]……a[n],程序必须回答这样的询问:对于给定的i,j,k,在a[i],a[i+1
],a[i+2]……a[j]中第k小的数是多少(1≤k≤j-i+1),并且,你可以改变一些a[i]的值,改变后,程序还能针对改
变后的a继续回答上面的问题。
Input
第一行有两个正整数n(1≤n≤10000),m(1≤m≤10000)。
分别表示序列的长度和指令的个数。
第二行有n个数,表示a[1],a[2]……a[n],这些数都小于10^9。
接下来的m行描述每条指令
每行的格式是下面两种格式中的一种。
Q i j k 或者 C i t
Q i j k (i,j,k是数字,1≤i≤j≤n, 1≤k≤j-i+1)
表示询问指令,询问a[i],a[i+1]……a[j]中第k小的数。
C i t (1≤i≤n,0≤t≤10^9)表示把a[i]改变成为t
m,n≤10000
Output
对于每一次询问,你都需要输出他的答案,每一个输出占单独的一行。
Sample Input
5 3
3 2 1 4 7
Q 1 4 3
C 2 6
Q 2 5 3
Sample Output
3
6
题解
昨天本来很垃圾,也就秒想出待修改整体二分怎么搞还算好点。
昨天已经写好题解了,不过在这里再说下理解。
整体二分就是把操作序列分治成和值域相关的子问题,不管是修改还是查询。
一个有趣的细节:
这两个都是正确的。
原因是整体二分由于右边的永远不会影响左边的,所以覆盖掉左边的位置并不会错。
确实挺好写,1A
Code:
1 |
|
上午luogu有场比赛,感觉还挺有意思,就参加了一下。
暂时前十qwq?