#include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #define REP(i,s,n) for(int i=(int)(s);i<(int)(n);i++) using namespace std; typedef long long int ll; typedef vector VI; typedef pair PI; const double EPS=1e-9; const int DEBUG = 0; int totient(int m) { int s = 0; REP(i, 1, m + 1) { if (__gcd(i, m) == 1) { ++s; } } return s; } ll calc(ll a, ll n, int m) { if (n == 0) { return 1; } if (m == 1) { return 0; } int t = totient(m); ll r = calc(a, n - 1, t); ll sum = 1; ll cur = a; while (r > 0) { if (r % 2 != 0) { sum *= cur; sum %= m; } cur *= cur; cur %= m; r /= 2; } if (DEBUG) { cout << "calc(" << a << ", " << n << ", " << m << ") = " << sum << endl; } return sum; } int main(void){ int a, n, m; cin >> a >> n >> m; cout << calc(a, n, m) << endl; }