class Union_Find(): def __init__(self,N): """0,1,...,n-1を要素として初期化する. N:要素数 """ self.n=N self.parents=[-1]*N self.rank=[0]*N def find(self, x): """要素xの属している族を調べる. x:要素 """ V=[] while self.parents[x]>=0: V.append(x) x=self.parents[x] for v in V: self.parents[v]=x return x def union(self, x, y): """要素x,yを同一視する. x,y:要素 """ x=self.find(x) y=self.find(y) if x==y: return if self.rank[x]素数のリスト,True->素数かどうかのリスト (False->[2,3,5,...],True->[False,False,True,True,False,True,...]) """ if N==0: return [None] T=[True]*(N+1) T[0]=None T[1]=False x=4 while x<=N: T[x]=False x+=2 x=9 while x<=N: T[x]=False x+=6 a=5 Flag=1 while a*a<=N: if T[a]: b=a*a c=2*a while b<=N: T[b]=False b+=c a+=2 if Flag else 4 Flag^=1 if mode: return T else: return [k for k in range(N+1) if T[k]] #================================================ N,P=map(int,input().split()) U=Union_Find(N+1) A=Sieve_of_Eratosthenes(N) for p in A: q=2*p while q<=N: U.union(p,q) q+=p print(U.size(P))