#include<iostream>
using namespace std;
long mod=129402307;
long f(long M)
{
	string s;
	cin>>s;
	long ret=0;
	for(int i=0;i<s.size();i++)ret=(ret*10+s[i]-'0')%M;
	return ret;
}
main()
{
	long N=f(mod);
	long M=f(mod-1);
	long ans=1;
	while(M)
	{
		if(M&1)ans=ans*N%mod;
		N=N*N%mod;
		M>>=1;
	}
	cout<<ans<<endl;
}