4535: 「CQOI2018」交错序列

内存限制:512 MB 时间限制:0.500 S
评测方式:文本比较 命题人:
提交:0 解决:0

题目描述

我们称一个仅由 $0,1$ 构成的序列为「交错序列」,当且仅当序列中没有相邻的 $1$(可以有相邻的 $0$)。例如,$000,001,101$ 都是交错序列,而 $110$ 则不是。 对于一个长度为 $n$ 的交错序列,统计其中 $0$ 和 $1$ 出现的次数,分别记为 $x$ 和 $y$。给定参数 $a,b$,定义一个交错序列的特征值为 $x^ay^b$。注意这里规定任何整数的 $0$ 次幂都等于 $1$(包括 $0^0=1$)。 显然长度为 $n$ 的交错序列可能有多个。我们想要知道,所有长度为 $n$ 的交错序列的特征值的和,除以 $m$ 的余数。($m$ 是一个给定的质数) 例如,全部长度为 $3$ 的交错串为:$000,001,010,100,101$。当 $a=1,b=2$ 时,可计算:$3^1\times0^2+2^1\times1^2+2^1\times1^2+2^1\times1^2+1^1\times2^2=10$。

输入

共一行,包含三个空格分开的整数 $n,a,b$ 和 $m$。

输出

共一行,为计算结果。

样例输入 复制

3 1 2 1009

样例输出 复制

10

提示

输入样例2


4 3 2 1009

输出样例2


204

数据范围:对于 $30\%$ 的数据,$1\leq n\leq 15$。 对于 $100\%$ 的数据,$1\leq n\leq 10^7,0\leq a,b\leq 45, m<10^8$。

来源/分类