#ATagc043d. [AGC043D] Merge Triplets

[AGC043D] Merge Triplets

题目描述

给你一个正整数 NN,计算可以按以下方法生成的 113N3N 的排列 (P1,P2,,P3N)(P_1,P_2,\cdots,P_{3N}) 的个数。

答案可以很大,所以你需要输出它对一个质数 MM 取模的值。

  • 构造 NN 个长度为 33 的序列 A1,A2,,ANA_1,A_2,\cdots,A_N,其中 113N3N 每个数字均恰好出现一次。
  • PP 初始为空,重复以下操作 3N3N 次:
    • 对于所有的非空序列 AiA_i,令 xx 为它们的第一个元素中最小的一个。
    • xx 所在的 AiA_i 中删除 xx,然后把 xx 加入 PP 的末尾。

输入格式

一行两个整数 N,MN,M1N2000,108M109+71\le N\le 2000,10^8\le M\le 10^9+7MM 为质数)。

输出格式

输出一行一个整数,表示答案对 MM 取模后的值。

样例 1

输入

1 998244353

输出

6

样例 2

输入

2 998244353

输出

261

样例 3

输入

314 1000000007

输出

182908545

说明/提示

样例 1 解释

所有长度为 33 的排列均满足条件。