#include using namespace std; const int MOD = 10000000; long long pow(long long x, long long n) { long long ret = 1; while (n > 0) { if (n & 1) ret = ret * x % MOD; // n の最下位bitが 1 ならば x^(2^i) をかける x = x * x % MOD; n >>= 1; // n を1bit 左にずらす } return ret; } int main() { long long a, b; cin >> a >> b; cout << pow(a, b) << endl; return 0; }