#P51297. 「BalticOI 2012 Day1」括号

「BalticOI 2012 Day1」括号

题目描述

译自 BalticOI 2012 Day1 T1. Brackets

一个正规括号序列的定义如下:

  • ()[] 是正规括号序列;
  • A 是正规括号序列,则 (A)[A] 也是正规括号序列;
  • AB 都是正规括号序列,则 AB 也是正规括号序列。

在包含至少一对方括号的正规括号序列中,我们将方括号(包括 [])都用 ( 代替,这样就可以得到一个非正规括号序列。

例如 ((((((())) 都是非正规括号序列,(( 可以由 [] 得到,((((())) 则可以由 []((()))([](()))(([]()))((([]))) 这四种正规括号序列得到。

你的任务是:给出一个非正规括号序列,求出有多少种正规括号序列,使得将其中的方括号用 ( 代替后,可以得到给定的非正规括号序列。

输入格式

第一行一个正整数 NN,代表给定序列的长度。

第二行一个长度为 NN 的字符串(只包含 ()),代表给定的非正规括号序列。

输出格式

输出要求的正规括号序列的数量对 109+910^9+9 取模的结果。

样例 1

4
((()
2

满足条件的正规括号序列有两种:[]()([])

8
((((((((
14

满足条件的正规括号序列有:[][][][][[]][][][[]][[]][][][[]][[[]]][][[][]][][][[][]][][[[]]][[[[]]]][[][[]]][[[]][]][[][][]][[[][]]][][[]][]

数据范围与提示

  • 对于 20%20\% 的数据:N50N \leq 50
  • 对于 45%45\% 的数据:N103N \leq 10^3
  • 对于 100%100\% 的数据:2N3×1042 \leq N \leq 3 \times 10^4