#include using namespace std; long long int a,r,n,mod; long long int mypow(long long int x,long long int n) { long long int res = 1; while(n>0) { if(n%2==1) { res = (x%mod) * (res%mod); res%=mod; } x = (x%mod) * (x%mod); x%=mod; n/=2; } return res; } long long int func(long long int n) { if(n==1) { return r%mod; } if(n%2==0) { long long int x = (mypow(r,n/2)%mod + (1%mod))%mod; x%=mod; return ((x%mod)*(func(n/2)%mod))%mod; } else { return ((r%mod)*((func(n-1)%mod)) + r%mod)%mod; } } int main(void) { cin.tie(0); ios::sync_with_stdio(false); cin >> a >> r >> n; mod = 1e9 + 7; if(n==1) { cout << (a*r)%mod << '\n'; return 0; } cout << ((((a%mod)*((func(n-1)%mod + 1%mod)%mod)%mod)*(r%mod))%mod) << '\n'; return 0; }