QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#537490 | #9221. Missing Boundaries | ttbchimbu999# | WA | 157ms | 23732kb | C++20 | 7.1kb | 2024-08-30 14:21:12 | 2024-08-30 14:21:14 |
Judging History
answer
// #include <bits/stdc++.h>
// using namespace std;
// #define fi first
// #define se second
// #define ll long long
// #define pb push_back
// #define ALL(x) (x).begin(), (x).end()
// #define GETBIT(mask, i) ((mask) >> (i) & 1)
// #define MASK(i) ((1LL) << (i))
// #define SZ(x) ((int)(x).size())
// #define CNTBIT(mask) __builtin_popcount(mask)
// template<class X, class Y> bool maximize(X &x, Y y){ if (x < y) {x = y; return true;} return false;};
// template<class X, class Y> bool minimize(X &x, Y y){ if (x > y) {x = y; return true;} return false;};
// typedef pair<int, int> ii;
// const int N = 2e5 + 5;
// const int INF = 1e9 + 7;
// int n, L;
// ii a[N], b[N];
// vector<ii> tmp;
// vector<int> lef, rig;
// set<ii> s;
// int len = 0;
// void read() {
// cin >> n >> L;
// len = 0;
// for(int i = 1; i <= n; i++) {
// cin >> a[i].first >> a[i].second;
// b[i] = a[i];
// if (a[i].fi != -1 && a[i].se != -1) len += a[i].se - a[i].fi + 1;
// }
// }
// bool check() {
// for(int i = 1; i <= n; i++) {
// if (a[i].first != -1 && a[i].second == -1) {
// a[i].second = a[i].first;
// }
// if (a[i].first == -1 && a[i].second != -1) {
// a[i].first = a[i].second;
// }
// }
// sort(a + 1, a + n + 1);
// ii pre = {0, 0};
// for(int i = 1; i <= n; i++) {
// if (a[i].fi == -1 && a[i].se == -1) continue;
// if (pre.fi == 0) pre = a[i];
// else {
// if (pre.fi <= a[i].fi && a[i].fi <= pre.se) return 0;
// pre = a[i];
// }
// }
// return 1;
// }
// void solve() {
// if (check() == 0) {
// cout << "NIE\n";
// return;
// }
// swap(a, b);
// s.clear();
// tmp.clear();
// int cnt = 0;
// for(int i = 1; i <= n; i++) {
// if (a[i].first == -1 && a[i].second == -1) ++cnt;
// if (a[i].first != -1 && a[i].second != -1) {
// s.insert(a[i]);
// }
// if (a[i].first == -1 && a[i].second != -1) {
// tmp.push_back({a[i].second, 1});
// }
// if (a[i].first != -1 && a[i].second == -1) {
// tmp.push_back({a[i].first, 0});
// }
// }
// sort(ALL(tmp));
// lef.clear();
// rig.clear();
// for(int i = 0; i < SZ(tmp); i++) {
// int p = tmp[i].fi;
// cout << p << ' ' << tmp[i].se << endl;
// if (i < SZ(tmp) - 1 && tmp[i].se == 0 && tmp[i + 1].se == 1) {
// auto it = s.lower_bound({p, p});
// if ((*it).fi > tmp[i + 1].fi) {
// s.insert({p, tmp[i + 1].fi});
// ++i;
// }
// else {
// lef.push_back(tmp[i].fi);
// }
// }
// else {
// if (tmp[i].se == 0) lef.push_back(tmp[i].fi);
// else rig.push_back(tmp[i].fi);
// }
// }
// sort(ALL(lef), greater<int>());
// for(int p: lef) {
// auto it = s.lower_bound({p, p});
// cerr << p << endl;
// if (it == s.end()) s.insert({p, L});
// else s.insert({p, (*it).fi - 1});
// }
// sort(ALL(rig));
// for(int p: rig) {
// auto it = s.upper_bound({p, p});
// if (it == s.begin()) s.insert({1, p});
// else {
// --it;
// s.insert({(*it).se + 1, p});
// }
// }
// int pre = 0, need = 0;
// for(auto it: s) {
// cerr << it.fi << ' ' << it.se << endl;
// if (it.fi != pre + 1) ++need;
// pre = it.se;
// }
// if (pre != L) ++need;
// cerr << need << ' ' << cnt << ' ' << len << endl;
// if (need <= cnt && cnt <= L - len) cout << "TAK";
// else cout << "NIE";
// cout << endl;
// }
// signed main() {
// ios_base::sync_with_stdio(0); cin.tie(0); cout.tie(0);
// if (fopen("long.inp", "r")) {
// freopen("long.inp", "r", stdin);
// freopen("long.out", "w", stdout);
// }
// int test = 1;
// cin >> test;
// while(test--) {
// read();
// solve();
// }
// return 0;
// }
#include <bits/stdc++.h>
#define fi first
#define se second
using namespace std;
const int N = 2e5 + 5;
typedef pair<int, int> ii;
int n, L;
pair<int, int> a[N];
vector<pair<int, int> > b;
map<int, bool> mark;
set<pair<int, int>> s;
void reinit() {
b.clear();
mark.clear();
s.clear();
}
void solve() {
cin >> n >> L;
bool ok = 1;
int cnt = 0;
for (int i = 1; i <= n; ++i) {
cin >> a[i].first >> a[i].second;
if (a[i].first != -1 && a[i].second == -1) {
b.push_back({a[i].first, 0});
mark[a[i].first] = 1;
a[i].second = a[i].first;
}
else if (a[i].first == -1 && a[i].second != -1) {
b.push_back({a[i].second, 1});
a[i].first = a[i].second;
mark[a[i].second] = 1;
}
else if (a[i].first == -1 && a[i].second == -1) ++cnt;
else {
mark[a[i].first] = mark[a[i].second] = 1;
if (a[i].first < a[i].second) {
mark[a[i].first + 1] = mark[a[i].second - 1] = 1;
}
}
}
sort(a + 1, a + 1 + n);
//for(int i = 1; i <= n; i++) cout << a[i].first << ' ' << a[i].second << endl;
//return;
{
for(int i = 1; i <= n; i++) {
if (a[i].first != -1 && a[i].second == -1) {
a[i].second = a[i].first;
}
if (a[i].first == -1 && a[i].second != -1) {
a[i].first = a[i].second;
}
}
sort(a + 1, a + n + 1);
ii pre = {0, 0};
for(int i = 1; i <= n; i++) {
if (a[i].fi == -1 && a[i].se == -1) continue;
if (pre.fi == 0) pre = a[i];
else {
if (pre.fi <= a[i].fi && a[i].fi <= pre.se) ok = 0;
pre = a[i];
}
}
}
if (!ok) {
cout << "NIE\n";
return;
}
sort(b.begin(), b.end());
int mn = 0, pre = 0;
for (auto &i : b) {
int pos = i.first, type = i.second;
if (pos == pre) ok = 0;
if (pos > 1 && type == 0 && !mark[pos - 1]) ++mn;
// cerr << "DB>> " << pos << " : " << mn << '\n';
pre = pos;
}
int mx = L - b.size();
if (!b.empty()) {
if (b.back().first < L && b.back().second == 1) ++mn;
}
else {
mn = 1;
mx = L;
}
if (ok && mn <= cnt && cnt <= mx) cout << "TAK\n";
else cout << "NIE\n";
}
signed main() {
ios_base::sync_with_stdio(0); cin.tie(0); cout.tie(0);
#ifdef LOCAL
// freopen("TEST.inp", "r", stdin);
// freopen("TEST.out", "w", stdout);
#else
// freopen("TEST.inp", "r", stdin);
// freopen("TEST.out", "w", stdout);
#endif
if (fopen("long.inp", "r")) {
freopen("long.inp", "r", stdin);
freopen("long.out", "w", stdout);
}
int t;
cin >> t;
while (t--) {
solve();
reinit();
}
return 0;
}
詳細信息
Test #1:
score: 100
Accepted
time: 0ms
memory: 3712kb
input:
3 4 51 1 -1 11 50 -1 -1 -1 10 3 2 -1 -1 -1 -1 -1 -1 2 3 1 2 2 3
output:
TAK NIE NIE
result:
ok 3 lines
Test #2:
score: -100
Wrong Answer
time: 157ms
memory: 23732kb
input:
1 200000 1000000000 490669427 -1 224278942 224287156 821104480 -1 861696576 861702036 807438935 807440055 574078002 574083717 465630141 -1 195378188 -1 -1 13500961 -1 977536179 92893115 -1 -1 661145418 -1 215804863 -1 685338515 544348999 -1 465532902 -1 130346949 -1 -1 526666304 635604584 635605404 ...
output:
NIE
result:
wrong answer 1st lines differ - expected: 'TAK', found: 'NIE'