CF1095E.Almost Regular Bracket Sequence

传统题 时间 2000 ms 内存 256 MiB 9 尝试 1 已通过 1 标签

Almost Regular Bracket Sequence

You are given a bracket sequence ss consisting of nn opening '(' and closing ')' brackets.

A regular bracket sequence is a bracket sequence that can be transformed into a correct arithmetic expression by inserting characters '1' and '+' between the original characters of the sequence. For example, bracket sequences "()()", "(())" are regular (the resulting expressions are: "(1)+(1)", "((1+1)+1)"), and ")(" and "(" are not.

You can change the type of some bracket sis_i. It means that if si=s_i = ')' then you can change it to '(' and vice versa.

Your task is to calculate the number of positions ii such that if you change the type of the ii-th bracket, then the resulting bracket sequence becomes regular.

Input

The first line of the input contains one integer nn (1n1061 \le n \le 10^6) — the length of the bracket sequence.

The second line of the input contains the string ss consisting of nn opening '(' and closing ')' brackets.

Output

Print one integer — the number of positions ii such that if you change the type of the ii-th bracket, then the resulting bracket sequence becomes regular.

Samples

6
(((())
3
6
()()()
0
1
)
0
8
)))(((((
0

在线编程 IDE

建议全屏模式获得最佳体验