結果
| 問題 |
No.2592 おでぶなおばけさん 2
|
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2023-12-20 00:15:01 |
| 言語 | C++23 (gcc 13.3.0 + boost 1.87.0) |
| 結果 |
AC
|
| 実行時間 | 294 ms / 2,500 ms |
| コード長 | 874 bytes |
| コンパイル時間 | 1,103 ms |
| コンパイル使用メモリ | 80,004 KB |
| 実行使用メモリ | 6,944 KB |
| 最終ジャッジ日時 | 2024-09-27 09:30:55 |
| 合計ジャッジ時間 | 25,875 ms |
|
ジャッジサーバーID (参考情報) |
judge1 / judge2 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 1 |
| other | AC * 83 |
ソースコード
#include <iostream>
using namespace std;
using ll = long long;
constexpr int Z[3] = {(int)1e9-71, (int)1e9+7, (int)1e9+9};
int main() {
int n, q;
ll k;
cin >> n >> q >> k;
int ps[n+1][3];
ps[0][0] = ps[0][1] = ps[0][2] = 0;
int powk[3] = {1, 1, 1};
for (int i = 1; i <= n; i++) {
ll a;
cin >> a;
for (int j = 0; j < 3; j++) {
int moda = (a % Z[j] + Z[j]) % Z[j];
ps[i][j] = (ps[i-1][j] + 1ll * moda * powk[j]) % Z[j];
powk[j] = powk[j] * (k % Z[j]) % Z[j];
}
}
while (q--) {
int l, r;
cin >> l >> r;
bool ans = false;
for (int j = 0; j < 3; j++) {
if ((ps[r][j] - ps[l-1][j] + Z[j]) % Z[j] != 0) {
ans = true;
}
}
cout << (ans ? "Yes" : "No") << endl;
}
return 0;
}