A847.Pair Programming--Gold
提高+/省选-
通过率:0%
时间限制:1.00s
内存限制:128MB
题目描述
A program consists of a sequence of instructions, each of which is of one of
the following forms:
- ×d, where d is a digit in the range [0,9]
- +s, where s is a string denoting the name of a variable. Within a program, all variable names must be distinct.
The result of executing a program is defined to be the expression that results
after applying each instruction in order, starting with 0. For example, the
result of executing the program [×3,+x,+y,×2,+z] is the
expression (0×3+x+y)×2+z=2×x+2×y+z. Different
programs, when executed may produce the same expressions; for example,
executing [+w,×0,+y,+x,×2,+z,×1] would also result in the
expression 2×x+2×y+z.
Bessie and Elsie each have programs of N (1≤N≤2000) instructions.
They will interleave these programs to produce a new program of length 2N.
Note that there are N!×N!(2N)! ways to do this, but not all
such programs, when executed, will produce distinct expressions.
Count the number of distinct expressions that may be produced by executing
Bessie and Elsie's interleaved program, modulo 109+7.
Each input contains T (1≤T≤10) test cases that should be solved
independently. It is guaranteed that the sum of N over all test cases does
not exceed 2000.
输入格式
The first line of the input contains T, the number of test cases.
The first line of each test case contains N.
The second line of each test case contains Bessie's program, represented by a
string of length N. Each character is either a digit d∈[0,9],
representing an instruction of type 1, or the character +, representing an
instruction of type 2.
The third line of each test case contains Elsie's program in the same format
as Bessie's.
Within a test case, the variable names among all instructions are distinct.
Note that their actual names are not provided, as they do not affect the
answer.
输出格式
The number of distinct expressions that may be produced by executing Bessie
and Elsie's interleaved programs, modulo 109+7.
输入输出样例
输入#1
4 1 0 1 3 12+ +02 3 0++ ++9 4 5+++ +6+1
输出#1
1 3 9 9
说明/提示
For the first test case, the two possible interleaved programs are [×1,×0] and [×0,×1]. These will both produce the expression
0 when executed.
For the second test case, executing an interleaving of [×1,×2,+x] and [+y,×0,×2] could produce one of the expressions 0,
x, or 2×x.