
求助
#include<bits/stdc++.h>
using namespace std;
const int N=50010;
#define ll long long 
ll n,g,p=999911659,a[5],b[5]={0,2,3,4679,35617},jc[N],t[5],sum;
ll quickmi(ll a,ll b,ll p)
{
	ll ans=1;
	while(b){
		if(b&1) ans=ans*a%p;
		a=a*a%p; 
		b>>=1;
	}
	return ans;
}
void exgcd(ll a,ll b,ll &x,ll &y)
{
	if(b==0) {
		x=1;y=0;return;
	}
	exgcd(b,a%b,x,y);
	ll z=x;x=y;y=z-(a/b)*y;
	return;
}
ll C(ll n,ll m,ll p)
{
	if(n<m) return 0;
	return jc[n]*quickmi(jc[m],p-2,p)%p*quickmi(jc[n-m],p-2,p)%p;
}
ll lucas(ll n,ll m,ll p)
{
	if(n<m) return 0;
	if(!n) return 1;
	return lucas(n/p,m/p,p)*C(n%p,m%p,p)%p; 
}
int main()
{
	cin>>n>>g;
	if(g%p==0) {
		cout<<"0";
		return 0;
	}
	for(ll i=1;i<=4;i++){
		jc[0]=1;
		for(ll j=1;j<=b[i];j++)
			jc[j]=(jc[j-1]*j)%b[i];
		for(ll j=1;j*j<=n;j++){
			if(n%j!=0) continue;
			a[i]=(a[i]+lucas(n,j,b[i]))%b[i];
			if(n%j!=j) a[i]=(a[i]+lucas(n,n/j,b[i]))%b[i];
			
		}	
		sum=(sum+a[i]*((p-1)/b[i])%(p-1)*quickmi((p-1)/b[i],b[i]-2,b[i]))%(p-1);
	}
	cout<<quickmi(g,sum,p);
	return 0;
}