From 28a7b533dd024b2edf4aa4dd95aa70110c217334 Mon Sep 17 00:00:00 2001 From: Macesuted Date: Sat, 27 Jul 2024 12:21:15 +0800 Subject: [PATCH] =?UTF-8?q?HDOJ:=207459=20=E6=B8=B8=E8=B5=B0?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- HDOJ/7459.cpp | 89 +++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 89 insertions(+) create mode 100644 HDOJ/7459.cpp diff --git a/HDOJ/7459.cpp b/HDOJ/7459.cpp new file mode 100644 index 0000000..f4db5d3 --- /dev/null +++ b/HDOJ/7459.cpp @@ -0,0 +1,89 @@ +/** + * @file 7459.cpp + * @author Macesuted (i@macesuted.moe) + * @date 2024-07-27 + * + * @copyright Copyright (c) 2024 + * + */ + +#include +using namespace std; + +#ifndef LOCAL +#define endl '\n' +#endif + +bool mem1; + +typedef pair pii; + +int tl, tr; +bool flag; + +map S; + +void check(pii a, pii b) { + if (((a.first + a.second) & 1) ^ ((b.first + b.second) & 1)) tl = max(tl, a.first + 1); + if (a.second == 1 && b.second > 1) tr = min(tr, b.first - b.second + 1); + if (abs(a.second - b.second) > b.first - a.first) flag = false; + return; +} + +void insert(int tim, int pos) { + if (S.count(tim) && S[tim] != pos) return flag = false, void(); + S[tim] = pos; + auto p = S.find(tim); + if (p != S.begin()) check(*--p, {tim, pos}); + p = S.find(tim); + if (++p != S.end()) check({tim, pos}, *p); + return; +} + +void solve(void) { + int n, m; + cin >> n >> m; + tl = 0, tr = 1 << 30, flag = true; + S.clear(), insert(0, 1); + while (m--) { + int op; + cin >> op; + if (op == 0) { + int p, q; + cin >> p >> q; + if (tl > tr || !flag) continue; + insert(q, p); + } else if (op == 1) { + if (tl > tr || !flag) + cout << "bad" << endl; + else + cout << tl << endl; + } else { + if (tl > tr || !flag) + cout << "bad" << endl; + else if (tr == (1 << 30)) + cout << "inf" << endl; + else + cout << tr << endl; + } + } + return; +} + +bool mem2; + +int main() { + ios::sync_with_stdio(false), cin.tie(nullptr); +#ifdef LOCAL + cerr << "Memory Cost: " << abs(&mem1 - &mem2) / 1024. / 1024. << "MB" << endl; +#endif + + int _ = 1; + cin >> _; + while (_--) solve(); + +#ifdef LOCAL + cerr << "Time Cost: " << clock() * 1000. / CLOCKS_PER_SEC << "MS" << endl; +#endif + return 0; +} \ No newline at end of file