[AHOI2022] 山河重整
题目描述
生活在 $998244353$ 号小宇宙的艾和兰收到了归零者的讯息,决定响应回归运动。他们需要把大部分的物质归还给大宇宙,只留下极少的物质用于在新宇宙重建自己的文明。
艾和兰的文明总共有 $n$ 个关键信息,编号为 $1, 2, \ldots, n$。他们需要保留的信息是这些关键信息的一个子集 $S$。对于一个编号为 $x$ 的信息,只要 $S$ 中一个子集的编号和等于 $x$,那么他们设计的漂流瓶就可以在新宇宙将 $x$ 还原出来。
艾和兰不禁想要思考,他们有多少种选择子集 $S$ 的方案,使得关键信息 $1, 2, \ldots, n$ 均能被还原?艾和兰自然是只用 $1$ 微秒就算出了方案数的精确数值,现在他们想让你帮忙验算。由于方案数可能很大,你只需要输出方案数对 $M$ 取模的结果。
输入输出格式
输入格式
一行输入两个正整数 $N, M$。
输出格式
输出一行一个整数,表示答案对 $M$ 取模的结果。
输入输出样例
输入样例 #1
4 1000000007
输出样例 #1
3
输入样例 #2
10 1000000007
输出样例 #2
180
输入样例 #3
1000 65472
输出样例 #3
2136
输入样例 #4
100000 100
输出样例 #4
96
说明
**【样例解释 \#1】**
总共有以下 $3$ 个集合满足条件:
- $\{ 1, 2, 3 \}$
- $\{ 1, 2, 4 \}$
- $\{ 1, 2, 3, 4 \}$
**【数据范围】**
对于 $100 \%$ 的数据,保证 $1 \le N \le 5 \times {10}^5$,$2 \le M \le 1.01 \times {10}^9$。
| 测试点编号 | $N \le$ | $M \le$ |
|:-:|:-:|:-:|
| $1 \sim 2$ | $20$ | $1.01 \times {10}^9$ |
| $3 \sim 4$ | $100$ | $1.01 \times {10}^9$ |
| $5 \sim 6$ | $5000$ | $1.01 \times {10}^9$ |
| $7$ | $3 \times {10}^5$ | $127$ |
| $8$ | $5 \times {10}^5$ | $127$ |
| $9$ | $3 \times {10}^5$ | $1.01 \times {10}^9$ |
| $10$ | $5 \times {10}^5$ | $1.01 \times {10}^9$ |