結果
問題 |
No.673 カブトムシ
|
ユーザー |
|
提出日時 | 2021-12-11 03:24:18 |
言語 | C++17 (gcc 13.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 14 ms / 2,000 ms |
コード長 | 800 bytes |
コンパイル時間 | 1,926 ms |
コンパイル使用メモリ | 192,388 KB |
最終ジャッジ日時 | 2025-01-26 07:41:47 |
ジャッジサーバーID (参考情報) |
judge4 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 4 |
other | AC * 14 |
ソースコード
#include <bits/stdc++.h> 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; }