Preparando MOJI

Wrap Around

2000ms 262144K

Description:

You are given a binary string $$$s$$$.

Find the number of distinct cyclical binary strings of length $$$n$$$ which contain $$$s$$$ as a substring.

The cyclical string $$$t$$$ contains $$$s$$$ as a substring if there is some cyclical shift of string $$$t$$$, such that $$$s$$$ is a substring of this cyclical shift of $$$t$$$.

For example, the cyclical string "000111" contains substrings "001", "01110" and "10", but doesn't contain "0110" and "10110".

Two cyclical strings are called different if they differ from each other as strings. For example, two different strings, which differ from each other by a cyclical shift, are still considered different cyclical strings.

Input:

The first line contains a single integer $$$n$$$ ($$$1 \le n \le 40$$$) — the length of the target string $$$t$$$.

The next line contains the string $$$s$$$ ($$$1 \le |s| \le n$$$) — the string which must be a substring of cyclical string $$$t$$$. String $$$s$$$ contains only characters '0' and '1'.

Output:

Print the only integer — the number of distinct cyclical binary strings $$$t$$$, which contain $$$s$$$ as a substring.

Sample Input:

2
0

Sample Output:

3

Sample Input:

4
1010

Sample Output:

2

Sample Input:

20
10101010101010

Sample Output:

962

Note:

In the first example, there are three cyclical strings, which contain "0" — "00", "01" and "10".

In the second example, there are only two such strings — "1010", "0101".

Informação

Codeforces

Provedor Codeforces

Código CF1038F

Tags

dpstrings

Submetido 0

BOUA! 0

Taxa de BOUA's 0%

Datas 09/05/2023 09:38:44

Relacionados

Nada ainda