class FenwickTree: def __init__(self,n,M): self._n=n self.data=[0]*n self.M=M def add(self,p,x): p+=1 while p<=self._n: self.data[p-1]+=x self.data[p-1]%=self.M p+=p&(-p) def sum(self,left,right): return (self._sum(right)-self._sum(left))%self.M def _sum(self,r): s=0 while r>0: s+=self.data[r-1] s%=self.M r-=r&(-r) return s n,M=map(int,input().split()) f=[[] for i in range(n+1)] for i in range(1,n+1): for j in range(i,n+1,i): f[j]+=[i] fb=[1,1] for i in range(2,n+1): fb+=[(M//i)*fb[M%i]*(-1)%M] q=[0]*(n+1) r=[[] for i in range(n+1)] ft=FenwickTree(n+1,M) for i in range(3,n+1): for j in r[i]: ft.add(j,-q[j]) q[i]+=ft.sum(i-i//2,i) q[i]+=i q[i]*=fb[i-len(f[i])] q[i]%=M ft.add(i,q[i]*len(f[i])) for j in f[i]: if i+j<=n: r[i+j]+=[i] print(q[n])