#include <bits/stdc++.h>
using namespace std;
int main() {
long long n, m;
scanf("%lld", &n);
scanf("%lld", &m);
long long i, j, a[10005]={0}, x;
a[0]=1;
a[1]=1;
a[2]=2%m;
for(i=3; i<=n; i++){
for(j=0; j<=(i-1)/2; j++){
a[i]=(a[i]+a[i-1-j]*a[j])%m;
}
a[i]=a[i]*2%m;
// if(i%2==0) a[i]=(a[i/2]+a[i/2-1])%m;
if(i%2==1) a[i]=(a[i]-a[(i-1)/2]*a[(i-1)/2])%m;
}
x=a[n]%m;
printf("%d", x);
}
I2luY2x1ZGUgPGJpdHMvc3RkYysrLmg+CnVzaW5nIG5hbWVzcGFjZSBzdGQ7CiAKaW50IG1haW4oKSB7Cglsb25nIGxvbmcgbiwgbTsKCXNjYW5mKCIlbGxkIiwgJm4pOwoJc2NhbmYoIiVsbGQiLCAmbSk7Cglsb25nIGxvbmcgaSwgaiwgYVsxMDAwNV09ezB9LCB4OwoJYVswXT0xOwoJYVsxXT0xOwoJYVsyXT0yJW07CgkKCQoJZm9yKGk9MzsgaTw9bjsgaSsrKXsKCQlmb3Ioaj0wOyBqPD0oaS0xKS8yOyBqKyspewoJCQlhW2ldPShhW2ldK2FbaS0xLWpdKmFbal0pJW07CgkJfQoJCWFbaV09YVtpXSoyJW07CgkJLy8gaWYoaSUyPT0wKSBhW2ldPShhW2kvMl0rYVtpLzItMV0pJW07IAoJCWlmKGklMj09MSkgYVtpXT0oYVtpXS1hWyhpLTEpLzJdKmFbKGktMSkvMl0pJW07CgkJCgl9Cgl4PWFbbl0lbTsKCXByaW50ZigiJWQiLCB4KTsKfSA=