結果
問題 |
No.673 カブトムシ
|
ユーザー |
|
提出日時 | 2018-04-20 22:40:21 |
言語 | C (gcc 13.3.0) |
結果 |
AC
|
実行時間 | 1 ms / 2,000 ms |
コード長 | 663 bytes |
コンパイル時間 | 143 ms |
コンパイル使用メモリ | 30,592 KB |
実行使用メモリ | 6,944 KB |
最終ジャッジ日時 | 2024-06-30 06:09:26 |
合計ジャッジ時間 | 882 ms |
ジャッジサーバーID (参考情報) |
judge2 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 4 |
other | AC * 14 |
ソースコード
#include <stdio.h> #define MOD 1000000007 typedef long long ll; ll modpow(ll a, ll p, ll m) { a %= m; ll ans = 1; while(p > 0) { ans = (ans * ((p&1) ? a : 1))%m; p >>= 1; a = (a*a)%m; } return ans; } // B*C*(C^(D)-1)/(C-1) or B*D(C==1) int main(void) { ll B, C, D, ans; scanf("%lld %lld %lld", &B, &C, &D); B %= MOD; C %= MOD; ans = (B*C)%MOD; if(C != 1) { ans = (ans*(modpow(C, D, MOD) - 1)%MOD)%MOD; ans = (ans*(modpow(C-1, MOD-2, MOD))%MOD)%MOD; } else { D %= MOD; ans = (ans*D)%MOD; } printf("%lld\n", ans); return 0; }