#include #include #include #include #include #include #include #include #include #define L64 long long #define MOD (1000000007LL) L64 modpow(L64 src, L64 pow, L64 mod) { L64 res = 1; while (0 < pow) { if (pow % 2 == 1) { res = (res * src) % mod; pow--; } src = (src * src) % mod; pow /= 2; } return res; } L64 modinv(L64 src, L64 mod) { return modpow(src, mod - 2, mod); } int main(void) { L64 a, b, c; scanf("%lld^%lld^%lld", &a, &b, &c); L64 r1 = modpow(a % MOD, b, MOD); r1 = modpow(r1, c, MOD); L64 r2 = modpow(b % MOD, c, MOD - 1LL); r2 = modpow(a % MOD, r2, MOD); std::cout << r1 << " " << r2 << std::endl; }