結果
問題 | No.142 単なる配列の操作に関する実装問題 |
ユーザー | maine_honzuki |
提出日時 | 2021-05-14 21:41:53 |
言語 | C++17 (gcc 12.3.0 + boost 1.83.0) |
結果 |
AC
|
実行時間 | 2,667 ms / 5,000 ms |
コード長 | 1,231 bytes |
コンパイル時間 | 789 ms |
コンパイル使用メモリ | 85,132 KB |
実行使用メモリ | 23,208 KB |
最終ジャッジ日時 | 2024-10-02 00:54:38 |
合計ジャッジ時間 | 15,165 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge3 |
(要ログイン)
テストケース
テストケース表示入力 | 結果 | 実行時間 実行使用メモリ |
---|---|---|
testcase_00 | AC | 1,958 ms
23,084 KB |
testcase_01 | AC | 2,523 ms
23,208 KB |
testcase_02 | AC | 2,667 ms
23,088 KB |
testcase_03 | AC | 1,874 ms
23,072 KB |
testcase_04 | AC | 2,230 ms
23,204 KB |
ソースコード
#include <algorithm> #include <bitset> #include <iostream> #include <string> #include <vector> using namespace std; int main() { cin.tie(nullptr); ios::sync_with_stdio(false); int N, S, X, Y, Z; cin >> N >> S >> X >> Y >> Z; vector<long long> A(N); A[0] = S; for (int i = 1; i < N; i++) { (A[i] = (X * A[i - 1] + Y)) %= Z; } const int len = 1e5; bitset<len> bit[25], all; all.set(); for (int i = 0; i < N; i++) { bit[i / len][i % len] = A[i] % 2; } int Q; cin >> Q; while (Q--) { int S, T, U, V; cin >> S >> T >> U >> V; S--; U--; bitset<len> tmp; int P = (S / len + 1) * len; if (P <= T) { tmp |= bit[S / len] >> (S % len); tmp |= (bit[P / len] & (all >> (len - (T - P)))) << (P - S); } else { tmp |= (bit[S / len] >> (S % len)) & (all >> (len - (T - S))); } int Q = (U / len + 1) * len; bit[U / len] ^= tmp << (U % len); bit[Q / len] ^= tmp >> (Q - U); } string ans; for (int i = 0; i < N; i++) { ans.push_back(char(bit[i / len][i % len] ? 'O' : 'E')); } cout << ans << endl; }