atcoder#ARC089D. [ARC089F] ColoringBalls
[ARC089F] ColoringBalls
Score : points
Problem Statement
There are white balls arranged in a row, numbered from left to right. AtCoDeer the deer is thinking of painting some of these balls red and blue, while leaving some of them white.
You are given a string of length . AtCoDeer performs the following operation for each from through in order:
- The -th operation: Choose a contiguous segment of balls (possibly empty), and paint these balls red if the -th character in is
r; paint them blue if the character isb.
Here, if a ball which is already painted is again painted, the color of the ball will be overwritten.
However, due to the properties of dyes, it is not possible to paint a white, unpainted ball directly in blue.
That is, when the -th character in is b, the chosen segment must not contain a white ball.
After all the operations, how many different sequences of colors of the balls are possible? Since the count can be large, find it modulo .
Constraints
- consists of
randb. - and are integers.
Input
Input is given from Standard Input in the following format:
Output
Print the number of the different possible sequences of colors of the balls after all the operations, modulo .
2 2
rb
9
There are nine possible sequences of colors of the balls, as follows:
ww, wr, rw, rr, wb, bw, bb, rb, br.
Here, r represents red, b represents blue and wrepresents white.
5 2
br
16
Since we cannot directly paint white balls in blue, we can only choose an empty segment in the first operation.
7 4
rbrb
1569
70 70
bbrbrrbbrrbbbbrbbrbrrbbrrbbrbrrbrbrbbbbrbbrbrrbbrrbbbbrbbrbrrbbrrbbbbr
841634130