Problem A
Bracket Sequence
Two great friends, Eddie John and Kris Cross, are attending the Brackets Are Perfection Conference. They wholeheartedly agree with the main message of the conference and they are delighted with all the new things they learn about brackets.
One of these things is a bracket sequence. If you
want to do a computation with
The brackets are only used to group multiplications and additions together. This means that you can remove all the operators, as long as you remember that addition is used for numbers outside any parentheses! A bracket sequence can then be shortened to
That is much better, because it saves on writing all those operators. Reading bracket sequences is easy, too. Suppose you have the following bracket sequence
You start with addition, so this is the same as the following:
You know the parentheses group a multiplication, so this is equal to
Then there is another level of parentheses: that groups an operation within a multiplication, so the operation must be addition.
Since bracket sequences are so much easier than normal expressions with operators, it should be easy to evaluate some big ones. We will even allow you to write a program to do it for you.
Note that
Input
-
One line containing a single integer
. -
One line consisting of
tokens, each being either (, ), or an integer . It is guaranteed that the tokens form a bracket sequence.
Output
Output the value of the given bracket sequence. Since this
may be very large, you should print it modulo
Sample Input 1 | Sample Output 1 |
---|---|
2 2 3 |
5 |
Sample Input 2 | Sample Output 2 |
---|---|
8 ( 2 ( 2 1 ) ) 3 |
9 |
Sample Input 3 | Sample Output 3 |
---|---|
4 ( 12 3 ) |
36 |
Sample Input 4 | Sample Output 4 |
---|---|
6 ( 2 ) ( 3 ) |
5 |
Sample Input 5 | Sample Output 5 |
---|---|
6 ( ( 2 3 ) ) |
5 |
Sample Input 6 | Sample Output 6 |
---|---|
11 1 ( 0 ( 583920 ( 2839 82 ) ) ) |
1 |