#cpsco2019s2c. [cpsco2019_s2_c]Delicious Burgers

[cpsco2019_s2_c]Delicious Burgers

問題文

バンズ文字列とは、以下によって定義される、文字 ( および ) からなる文字列のことです。

  1. 空文字列はバンズ文字列である。
  2. AA がバンズ文字列であるとき、(AA) を順に連結した文字列はバンズ文字列である。
  3. AA, BB がバンズ文字列であるとき、AABB を連結した文字列はバンズ文字列である。
  4. これら以外の文字列はバンズ文字列ではない。

上のようにしてバンズ文字列を生成するにあたって、 2. によって同時に追加された () をペアにして、これを対応バンズと呼ぶことにします。
バンズ文字列では、任意の文字がある対応バンズに属し、どの文字も複数の対応バンズに属さないことがわかります。

また、バーガー文字列とは、以下によって定義される、文字 ( , ) および | からなる文字列のことです。

  • 文字 | をすべて取り除くと、バンズ文字列になる。
  • 文字 |22つ以上連続しない。

長さ NN のバンズ文字列 SS が与えられます。 あなたは SS に文字 |KK 個挿入し、バーガー文字列を作ることにしました。
バーガー文字列に含まれるある対応バンズの美味しさとは、その2文字 () の間にある | の個数のことです。
バーガー文字列の美味しさとは、それに含まれるすべての対応バンズの美味しさの和のことです。

あなたが作ることのできるバーガー文字列の美味しさの最大値を求めてください。

制約

  • 1leqK<Nleq1051 \\leq K < N \\leq 10^5
  • KK, NN は整数である。
  • S=N|S|=N
  • SS はバンズ文字列である。

入力

入力は以下の形式で標準入力から与えられる。

NN KK SS

出力

作ることのできるバーガー文字列の美味しさの最大値を出力せよ。


入力例 1

6 1
(())()

出力例 1

2

((|))() を作るのが最適です。


入力例 2

8 2
((()))()

出力例 2

5

(((|)|))() を作るのが最適です。