CF1750F.Majority
普及/提高-
通过率:0%
AC君温馨提醒
该题目为【codeforces】题库的题目,您提交的代码将被提交至codeforces进行远程评测,并由ACGO抓取测评结果后进行展示。由于远程测评的测评机由其他平台提供,我们无法保证该服务的稳定性,若提交后无反应,请等待一段时间后再进行重试。
题目描述
Everyone was happy coding, until suddenly a power shortage happened and the best competitive programming site went down. Fortunately, a system administrator bought some new equipment recently, including some UPSs. Thus there are some servers that are still online, but we need all of them to be working in order to keep the round rated.
Imagine the servers being a binary string s of length n . If the i -th server is online, then si=1 , and si=0 otherwise.
A system administrator can do the following operation called electricity spread, that consists of the following phases:
- Select two servers at positions 1≤i<j≤n such that both are online (i.e. si=sj=1 ). The spread starts only from online servers.
- Check if we have enough power to make the spread. We consider having enough power if the number of turned on servers in range [i,j] is at least the number of turned off servers in range [i,j] . More formally, check whether 2⋅(si+si+1+…+sj)≥j−i+1 .
- If the check is positive, turn on all the offline servers in range [i,j] . More formally, make sk:=1 for all k from i to j .
We call a binary string s of length n rated if we can turn on all servers (i.e. make si=1 for 1≤i≤n ) using the electricity spread operation any number of times (possibly, 0 ). Your task is to find the number of rated strings of length n modulo m .
输入格式
The first and only line contains two integers n and m ( 1≤n≤5000 , 10≤m≤109 ) — the length of the string and the required module.
输出格式
Print a single integer — the number of rated binary strings of length n . Since this number can be large, print it modulo m .
输入输出样例
输入#1
2 100
输出#1
1
输入#2
3 10
输出#2
2
输入#3
4 3271890
输出#3
4
输入#4
17 123456
输出#4
32347
说明/提示
In the first example, the only rated string is 11. So the answer is 1 .
In the second example, the rated strings are:
- 111;
- 101, because we can perform an operation with i=1 and j=3 .
So the answer is 2 .In the third sample, the rated strings are:
- 1001;
- 1111;
- 1011;
-
So the answer is 4 .