結果
問題 |
No.1359 [Zelkova 3rd Tune] 四人セゾン
|
ユーザー |
👑 ![]() |
提出日時 | 2020-12-27 18:17:23 |
言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 558 ms / 2,000 ms |
コード長 | 1,028 bytes |
コンパイル時間 | 768 ms |
コンパイル使用メモリ | 75,836 KB |
実行使用メモリ | 6,528 KB |
最終ジャッジ日時 | 2024-12-25 16:40:22 |
合計ジャッジ時間 | 30,207 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 75 |
ソースコード
#include<iostream> #include<algorithm> #include<vector> using namespace std; using ll = long long; int power_mod(int a, int n, int m) { ll ans = 1; ll x = a % m; if (x < 0) x += m; while (n > 0) { if (n % 2 == 1) { ans = (ans * x) % m; } x = (x * x) % m; n /= 2; } return ans; } int max(vector<int> X) { int r = X[0]; for (auto x : X) if (x > r) r = x; return r; } int min(vector<int> X) { int r = X[0]; for (auto x : X) if (x < r) r = x; return r; } int unfairness(int p, int e, int a, int h) { int alpha = max({ p,e,a,h }); int beta = min({ p,e,a,h }); return alpha - beta; } void vector_input(vector<int>& X) { for (int i = 0; i < X.size(); i++) { cin >> X[i]; } sort(X.begin(), X.end()); } int main() { int N, K, M; cin >> N >> K >> M; vector<int> P(N), E(N), A(N), H(N); vector_input(P); vector_input(E); vector_input(A); vector_input(H); ll Y = 0; for (int i = 0; i < N; i++) { Y += power_mod(unfairness(P[i], E[i], A[i], H[i]), K, M); Y %= M; } cout << Y << endl; }