You are given a string $$$s$$$, consisting of lowercase Latin letters.
There's a cursor, initially placed between two adjacent letters of the string. The cursor can't be placed before the first or after the last letter.
In one move, you can perform one of three actions:
You are asked $$$m$$$ queries. In each query, you are given two integers $$$f$$$ and $$$t$$$, which correspond to two valid positions of the cursor in the string. In response to the query, you have to calculate the minimum number of operations required to move the cursor from position $$$f$$$ to position $$$t$$$.
The first line contains a string $$$s$$$ ($$$2 \le |s| \le 5 \cdot 10^4$$$), consisting of lowercase Latin letters.
The second line contains a single integer $$$m$$$ ($$$1 \le m \le 5 \cdot 10^4$$$) — the number of queries.
The $$$i$$$-th of the next $$$m$$$ lines contains two integers $$$f$$$ and $$$t$$$ ($$$1 \le f, t \le |s| - 1$$$) — the initial and the target positions of the cursor in the $$$i$$$-th query. Position $$$x$$$ means that the cursor is between the $$$x$$$-th and the $$$(x+1)$$$-st letters of the string ($$$1$$$-indexed).
For each query, print the minimum number of actions required to move the cursor from position $$$f$$$ to position $$$t$$$.
codecode 3 1 7 3 5 3 6
3 2 2
abcdefghij 3 1 9 9 1 5 5
8 8 0
aaaaaaaaaaaa 4 10 8 3 7 6 1 11 11
1 1 1 0
Name |
---|