結果
問題 |
No.673 カブトムシ
|
ユーザー |
|
提出日時 | 2018-04-20 22:37:56 |
言語 | C (gcc 13.3.0) |
結果 |
WA
|
実行時間 | - |
コード長 | 632 bytes |
コンパイル時間 | 184 ms |
コンパイル使用メモリ | 29,952 KB |
実行使用メモリ | 6,948 KB |
最終ジャッジ日時 | 2024-06-27 05:18:19 |
合計ジャッジ時間 | 825 ms |
ジャッジサーバーID (参考情報) |
judge2 / judge1 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 4 |
other | AC * 12 WA * 2 |
ソースコード
#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) 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 { ans = (ans*D)%MOD; } printf("%lld\n", ans); return 0; }