
Fax McClad, Croneria's most skillful bounty hunter, has recently found a list filled with identification strings of various members of the Dankey Kang Gang!
There are
Fax manually inputs all of the strings into a Cronerian government database, which sorts all of the strings by lexicographical order.
Now, Fax needs to make sure that he inputted the strings correctly. He will perform the following query
Can you help Fax to determine what the expected output should be?
Constraints
All characters are lowercase characters in the English alphabet.
In each query,
Subtask | Points | Additional constraints |
---|---|---|
1 | 15 | |
2 | 15 | |
3 | 50 | |
4 | 20 | No additional constraints. |
Input Specification
The first line of input will contain
The next line of input will contain
The next line of input will contain
i j
.
Output Specification
Output on separate lines the answer to each query.
Sample Input
bbbbb
4
4 c
3 a
2 b
4
3 5
2 3
4 4
3 4
Sample Output
b
a
c
b
Explanation for Sample Output
The strings in the list are initially in the order bbbbb
, bbbcb
, bbacb
, bbacb
.
After putting all the strings into the database, their order is bbacb
, bbacb
, bbbbb
, bbbcb
.
Comments
is this problem really tested and pass in python?
Will there be an editorial for this question? :)
I'm not sure whether the author is planning to write an editorial but the author's intended solution is to maintain the hashes of the string with a persistent segment tree.
However, there exists a nice divide and conquer solution. Break
into blocks of size 
where 
loops from 
to 
. For each block, we want to compute the relative order of the substring in this block among each of the 
versions of 
. We already have the relative order of the two halves of the block, so we can sort this and find the order of the entire block. It's important to not break ties in this solution (until the end). The time complexity of this is 
for each value of 
since over all the blocks (for a fixed 
), there are at most 
distinct substrings. So the final time complexity is 
.