#include using namespace std; typedef long long ll; typedef vector vll; typedef vector vvll; typedef pair P; typedef string str; typedef vector

vp; typedef vector vs; typedef vector vb; const ll mod=1e9; const ll inf=1e16; #define rep(i,m,n) for(ll i=m;i=n;i--) #define fi first #define se second #define chmax(x,y) x=max(x,y) #define chmin(x,y) x=min(x,y) #define eb(x) emplace_back(x) #define pb(x) pop_back(x) #define all(x) x.begin(),x.end() #define allr(x) x.rbegin(),x.rend() #define sum(x) accumulate(all(x),0) #define pc(x) __builtin_popcount(x) #define gll greater() void solve(){ ll n,m; cin >> n >>m; vll f(n+1,0); f[2]=1; rep(i,3,n+1) f[i]=(f[i-1]+f[i-2])%m; cout << f[n] << endl; } int main(){ cin.tie(nullptr); ios::sync_with_stdio(false); solve(); }