結果
問題 |
No.995 タピオカオイシクナーレ
|
ユーザー |
|
提出日時 | 2020-02-23 22:52:37 |
言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 42 ms / 2,000 ms |
コード長 | 1,180 bytes |
コンパイル時間 | 1,671 ms |
コンパイル使用メモリ | 166,332 KB |
実行使用メモリ | 6,824 KB |
最終ジャッジ日時 | 2024-10-10 22:21:32 |
合計ジャッジ時間 | 2,913 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 23 |
ソースコード
#include <bits/stdc++.h> using namespace std; using lint = long long; const lint mod = 1e9 + 7; #define all(x) (x).begin(), (x).end() lint power(lint base, lint exponent, lint module){ if(exponent % 2){ return power(base, exponent - 1, module) * base % module; }else if(exponent){ lint root_ans = power(base, exponent / 2, module); return root_ans * root_ans % module; }else{ return 1; } } int main(){ int N, M; lint K; cin >> N >> M >> K; lint p, q; cin >> p >> q; lint r = p * power(q, mod - 2, mod) % mod; lint milk_tea = 0; for(int i = 0; i < M; i++){ lint b; cin >> b; milk_tea += b; } milk_tea %= mod; lint kitchen = 0; for(int i = 0; i < N - M; i++){ lint b; cin >> b; kitchen += b; } kitchen %= mod; lint probability_milk = (1 + power((1 - r * 2 + mod * 2) % mod, K, mod)) * 500000004ll % mod; lint probability_kitchen = (1 - power((1 - r * 2 + mod * 2) % mod, K, mod) + mod) * 500000004ll % mod; cout << (milk_tea * probability_milk % mod + kitchen * probability_kitchen % mod) % mod << endl; }