QOJ.ac
QOJ
ID | Submission ID | Problem | Hacker | Owner | Result | Submit time | Judge time |
---|---|---|---|---|---|---|---|
#481 | #276415 | #6520. Classic Problem | Zhou_JK | isaunoya | Success! | 2023-12-06 00:08:07 | 2023-12-06 00:08:07 |
Details
Extra Test:
Wrong Answer
time: 317ms
memory: 16576kb
input:
1 100000 99998 1 2 1000000000 1 3 1000000000 1 4 1000000000 1 5 1000000000 1 6 1000000000 1 7 1000000000 1 8 1000000000 1 9 1000000000 1 10 1000000000 1 11 1000000000 1 12 1000000000 1 13 1000000000 1 14 1000000000 1 15 1000000000 1 16 1000000000 1 17 1000000000 1 18 1000000000 1 19 1000000000 1 20 ...
output:
1000099998
result:
wrong answer 1st numbers differ - expected: '199997', found: '1000099998'
ID | Problem | Submitter | Result | Time | Memory | Language | File size | Submit time | Judge time |
---|---|---|---|---|---|---|---|---|---|
#276415 | #6520. Classic Problem | isaunoya | WA | 314ms | 22232kb | C++23 | 2.6kb | 2023-12-05 20:59:19 | 2023-12-06 00:10:51 |
answer
#include <bits/stdc++.h>
using namespace std;
using ll = long long;
template <typename T> ostream &operator<<(ostream &out, const vector<T> &x) {
if (x.empty())
return out << "[]";
out << '[' << x[0];
for (int len = x.size(), i = 1; i < len; i++)
out << ',' << x[i];
return out << ']';
}
template <typename T> vector<T> ary(const T *a, int l, int r) {
return vector<T>{a + l, a + 1 + r};
}
template <typename T> void debug(T x) { cerr << x << '\n'; }
template <typename T, typename... S> void debug(T x, S... y) {
cerr << x << ' ', debug(y...);
}
const int N = 2e5 + 10, E = 4e7 + 10;
int T, n, m, k;
struct edges {
int u, v, w;
} e[E];
int p[N];
ll ans;
vector<int> to[N];
int cnt, fa[N];
int find(int x) { return fa[x] == x ? x : fa[x] = find(fa[x]); }
bool merge(int x, int y) {
x = find(x), y = find(y);
if (x == y)
return 0;
return cnt--, fa[x] = y, 1;
}
int vis[N], cur[N];
void link(int lim) {
for (int i = 1; i <= n; i++) {
for (int v : to[i])
vis[v] = 1;
int t = p[i - 1] + 1;
for (int l; (l = cur[i]) >= 1; cur[i]--) {
int d = -1;
if (!vis[l])
d = t - p[l];
else if (p[i] > t)
d = t - p[l];
else if (p[l - 1] + 1 < p[l])
d = t - p[l] + 1;
else
continue;
if (d > lim)
break;
if (merge(l, i))
ans += d;
}
for (int v : to[i])
vis[v] = 0;
}
}
void get() {
scanf("%d%d", &m, &k);
for (int i = 1; i <= k; i++) {
scanf("%d%d%d", &e[i].u, &e[i].v, &e[i].w);
p[++n] = e[i].u, p[++n] = e[i].v;
}
sort(p + 1, p + 1 + n), n = unique(p + 1, p + 1 + n) - p - 1;
if (p[n] != m)
p[++n] = m;
auto trs = [&](int &x) { x = lower_bound(p + 1, p + 1 + n, x) - p; };
for (int i = 1; i <= k; i++) {
trs(e[i].u), trs(e[i].v);
to[e[i].v].push_back(e[i].u);
}
for (int i = 1; i <= n; i++) {
ans += p[i] - p[i - 1] - 1;
cnt -= p[i] - p[i - 1] - 1;
}
for (int i = 1; i <= n; i++)
cur[i] = i - 1;
iota(fa, fa + 1 + n, 0);
sort(e + 1, e + 1 + k, [](edges x, edges y) { return x.w < y.w; });
cnt = n;
int i = 1;
for (int x = 0, lim = sqrt(k * 2) + 10; cnt > 1 && x < lim; x++) {
for (; i <= k && e[i].w <= x; i++)
if (merge(e[i].u, e[i].v))
ans += e[i].w;
link(x);
}
for (; i <= k; i++)
if (merge(e[i].u, e[i].v))
ans += e[i].w;
printf("%lld\n", ans);
}
void clr() {
for (int i = 1; i <= n; i++)
to[i].clear();
n = ans = 0;
}
int main() {
for (scanf("%d", &T); T--; clr())
get();
return 0;
}