#B290. 查找 404

查找 404

题目描述

Eve 有一个字符串 SS,该字符串仅由字符 *40 组成。字符 * 可以被替换为 40

Eve 想要计算所有可能通过替换 * 生成的字符串中,包含子序列 404 的总数。由于这个数字可能非常大,你需要其输出模 109+710^9 + 7 的结果。

例如,当 S=*S = \texttt{*} 时,可以替换为 40404044440444404444,其中分别有 1,2,0,0,01,2,0,0,0 个子序列,共 33 个。

输入格式

第一行一个整数 TT 表示数据组数。对于每组数据:

第一行一个整数 nn 表示 SS 的长度。

第二行一个字符串 SS

输出格式

对于每组数据,输出一行一个整数表示答案。

2
4
4*04
4
4*4*
4
3

数据范围

  • 对于 30% 的数据,1T101 \le T \le 101n,n101 \le n, \sum n \le 10
  • 对于 60% 的数据,1T1001 \le T \le 1001n,n1001 \le n, \sum n \le 100
  • 对于 100% 的数据,1T1051 \le T \le 10^51n1051 \le n \le 10^51n1061 \le \sum n \le 10^6SS 中仅包含 40* 三种字符。