結果
問題 |
No.665 Bernoulli Bernoulli
|
ユーザー |
|
提出日時 | 2017-09-27 21:39:08 |
言語 | C++11(廃止可能性あり) (gcc 13.3.0) |
結果 |
TLE
|
実行時間 | - |
コード長 | 603 bytes |
コンパイル時間 | 707 ms |
コンパイル使用メモリ | 55,012 KB |
実行使用メモリ | 13,824 KB |
最終ジャッジ日時 | 2024-11-15 17:53:54 |
合計ジャッジ時間 | 48,501 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 TLE * 1 |
other | TLE * 15 |
ソースコード
#include <cassert> #include <iostream> #define REP(i,s,n) for(int i=(int)(s);i<(int)(n);i++) using namespace std; typedef long long int ll; const ll mod = 1e9 + 7; ll powmod(ll a, ll e) { ll sum = 1; ll cur = a; while (e > 0) { if (e % 2) { sum = sum * cur % mod; } cur = cur * cur % mod; e /= 2; } return sum; } int main(void) { ll n; int k; cin >> n >> k; assert (1 <= n); assert (n <= (ll)1e16); assert (1 <= k); assert (k <= 10000); n %= mod; ll sum = 0; REP(i, 1, n + 1) { sum = (sum + powmod(i, k)) % mod; } cout << sum << endl; }