結果
問題 | No.793 うし数列 2 |
ユーザー | CuriousFairy315 |
提出日時 | 2019-02-22 21:59:35 |
言語 | C++17 (gcc 13.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 2 ms / 2,000 ms |
コード長 | 858 bytes |
コンパイル時間 | 574 ms |
コンパイル使用メモリ | 66,776 KB |
最終ジャッジ日時 | 2025-01-06 21:39:09 |
ジャッジサーバーID (参考情報) |
judge2 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 2 |
other | AC * 21 |
ソースコード
#include<iostream> using namespace std; // 575 const int MOD = 1000000007; long pow(long a, long b) { if (b == 0) return 1; if (b == 1) return a; if (b == 2) return a * a % MOD; return pow(pow(a, b >> 1), 2) * pow(a, b & 1) % MOD; } int main() { long N; cin >> N; cout << 333333336L * (pow(2, N + 2) * pow(5, N) % MOD - 1) % MOD; return 0; } /* 31536000のコメント解説欄 ここテンプレで用意してるから、A問題とかだとこの先空欄の危険あり また、コンテスト後に https://31536000.hatenablog.com/ で解説していると思うので、良かったら読んでねー まず、数列とみて考えてみる これはE(1)=13, E(N)=10E(N-1)+3 mod 10^9+7なので行列累乗でえいでは というわけで突っ込んだ、終わり https://www.wolframalpha.com/input/?i=f(1)%3D13,+f(N%2B1)%3D10f(N)%2B3 */