You are given two integers l and r, and a string directions consisting of exactly three 'D' characters and three 'R' characters.
For each integer x in the range [l, r] (inclusive), perform the following steps:
x has fewer than 16 digits, pad it on the left with leading zeros to obtain a 16-digit string.4 × 4 grid in row-major order (the first 4 digits form the first row from left to right, the next 4 digits form the second row, and so on).row = 0, column = 0), apply the 6 characters of directions in order:
'D' increments the row by 1.'R' increments the column by 1.The integer x is considered good if the recorded sequence is non-decreasing.
Return an integer representing the number of good integers in the range [l, r].
Example 1:
Input: l = 8, r = 10, directions = "DDDRRR"
Output: 2
Explanation:
The grid for x = 8:
| 0 | 0 | 0 | 0 |
| 0 | 0 | 0 | 0 |
| 0 | 0 | 0 | 0 |
| 0 | 0 | 0 | 8 |
(0,0) → (1,0) → (2,0) → (3,0) → (3,1) → (3,2) → (3,3)[0, 0, 0, 0, 0, 0, 8].The grid for x = 9:
| 0 | 0 | 0 | 0 |
| 0 | 0 | 0 | 0 |
| 0 | 0 | 0 | 0 |
| 0 | 0 | 0 | 9 |
[0, 0, 0, 0, 0, 0, 9].The grid for x = 10:
| 0 | 0 | 0 | 0 |
| 0 | 0 | 0 | 0 |
| 0 | 0 | 0 | 0 |
| 0 | 0 | 1 | 0 |
[0, 0, 0, 0, 0, 1, 0].Example 2:
Input: l = 123456789, r = 123456790, directions = "DDRRDR"
Output: 1
Explanation:
The grid for x = 123456789:
| 0 | 0 | 0 | 0 |
| 0 | 0 | 0 | 1 |
| 2 | 3 | 4 | 5 |
| 6 | 7 | 8 | 9 |
(0,0) → (1,0) → (2,0) → (2,1) → (2,2) → (3,2) → (3,3)[0, 0, 2, 3, 4, 8, 9].The grid for x = 123456790:
| 0 | 0 | 0 | 0 |
| 0 | 0 | 0 | 1 |
| 2 | 3 | 4 | 5 |
| 6 | 7 | 9 | 0 |
[0, 0, 2, 3, 4, 9, 0].Example 3:
Input: l = 1288561398769758, r = 1288561398769758, directions = "RRRDDD"
Output: 0
Explanation:
The grid for x = 1288561398769758:
| 1 | 2 | 8 | 8 |
| 5 | 6 | 1 | 3 |
| 9 | 8 | 7 | 6 |
| 9 | 7 | 5 | 8 |
(0,0) → (0,1) → (0,2) → (0,3) → (1,3) → (2,3) → (3,3)[1, 2, 8, 8, 3, 6, 8].Constraints:
1 <= l <= r <= 9 × 1015directions.length == 6directions consists of exactly three 'D' characters and three 'R' characters.Loading editor...
8 10 "DDDRRR"