No.2279 OR Insertion
レベル : / 実行時間制限 : 1ケース 2.000秒 / メモリ制限
: 512 MB / 標準ジャッジ問題
タグ : / 解いたユーザー数 76
作問者 : magsta / テスター : miscalc
タグ : / 解いたユーザー数 76
作問者 : magsta / テスター : miscalc
問題文最終更新日: 2023-04-20 09:34:47
問題文
0
と 1
のみで作られた長さ $N$ の文字列 $S$ が与えられます。
$S$ を $1$ 個以上の文字列に分割することを考えます。 具体的には、$S$ の隣り合う文字の間は $N-1$ 個ありますが、これらの中から $0$ 個以上選び、選んだ全ての間で分割します。 分割の仕方は $\displaystyle 2^{N-1}$ 種類となります。それぞれの分割の仕方に対する以下の方法で算出される値の総和を $998244353$ で割った余りを求めてください。
- 分割されたそれぞれの文字列を $2$ 進数整数とみなしたときの、それらの論理和 (OR)
入力
$N$ $S$
- $1 \leq N \leq 4000$
- $S$ は
0
と1
からなる長さ $N$ の文字列である - $N$ は整数である
出力
求めた値を出力し、最後に改行せよ。
サンプル
サンプル1
入力
3 110
出力
13
$\{110\}, \{1,10\}, \{11,0\}, \{1,1,0\}$ という $4$ 通りの分割の方法があります。それぞれの論理和 (OR) は以下のようになります。 ($10$ 進数で表現しています)
$\{110\}→6, \{1,10\}→3, \{11,0\}→3, \{1,1,0\}→1$
よって、総和は $13$ となります。
サンプル2
入力
30 011100101010100001110100101010
出力
625160010
提出するには、Twitter 、GitHub、 Googleもしくは右上の雲マークをクリックしてアカウントを作成してください。