P10040 [CCPC 2023 北京市赛] 替换

题目描述

给定一个长度为 $n$、字符集为 `01?` 的字符串 $s_1s_2 \cdots s_n$。 对于任意 $k \in [1,n]$,考察字符串 $T_k = t_1 t_2 \cdots t_n$,其中对于 $1 \le i \le n$, - 若 $s_i \ne$ `?`,则 $t_i = s_i$; - 否则,若 $i \le k$,$t_i =$ `0`; - 否则 $t_i = t_{i-k}$,你可以通过递归地算出 $t_{i-k}$ 得到 $t_i$。 容易发现 $T_k$ 的字符集为 `01`。你需要对所有 $k \in [1,n]$ 求出 $T_k$ 中 `1` 的个数。

输入格式

输入的第一行一个整数 $n (1 \le n \le 10^5)$ 表示字符串长度,第二行一个长度为 $n$、字符集为 `01?` 的字符串 $s_1s_2\cdots s_n$。

输出格式

输出 $n$ 行,第 $i$ 行一个整数表示 $T_i$ 中 `1` 的个数。

说明/提示

$T_1 =$ `10011`,$T_2 =$ `10111`,$T_3 =$ `10010`,$T_4 =$ `10011`,$T_5 =$ `10010`。