QOJ.ac
QOJ
ID | Problem | Submitter | Result | Time | Memory | Language | File size | Submit time | Judge time |
---|---|---|---|---|---|---|---|---|---|
#184403 | #4901. Speike & Tom | hos_lyric | 100 ✓ | 250ms | 115736kb | C++14 | 17.8kb | 2023-09-20 18:40:12 | 2023-09-20 18:40:13 |
Judging History
answer
#include <cassert>
#include <cmath>
#include <cstdint>
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <algorithm>
#include <bitset>
#include <complex>
#include <deque>
#include <functional>
#include <iostream>
#include <limits>
#include <map>
#include <numeric>
#include <queue>
#include <set>
#include <sstream>
#include <string>
#include <unordered_map>
#include <unordered_set>
#include <utility>
#include <vector>
using namespace std;
using Int = long long;
template <class T1, class T2> ostream &operator<<(ostream &os, const pair<T1, T2> &a) { return os << "(" << a.first << ", " << a.second << ")"; };
template <class T> ostream &operator<<(ostream &os, const vector<T> &as) { const int sz = as.size(); os << "["; for (int i = 0; i < sz; ++i) { if (i >= 256) { os << ", ..."; break; } if (i > 0) { os << ", "; } os << as[i]; } return os << "]"; }
template <class T> void pv(T a, T b) { for (T i = a; i != b; ++i) cerr << *i << " "; cerr << endl; }
template <class T> bool chmin(T &t, const T &f) { if (t > f) { t = f; return true; } return false; }
template <class T> bool chmax(T &t, const T &f) { if (t < f) { t = f; return true; } return false; }
#define COLOR(s) ("\x1b[" s "m")
template <class T> void bAdd(vector<T> &bit, int pos, const T &val) {
const int bitN = bit.size();
for (int x = pos; x < bitN; x |= x + 1) bit[x] += val;
}
template <class T> T bSum(const vector<T> &bit, int pos) {
T ret = 0;
for (int x = pos; x > 0; x &= x - 1) ret += bit[x - 1];
return ret;
}
template <class T> T bSum(const vector<T> &bit, int pos0, int pos1) {
return bSum(bit, pos1) - bSum(bit, pos0);
}
struct Hld {
int n, rt;
// needs to be tree
// vertex lists
// modified in build(rt) (parent removed, heavy child first)
vector<vector<int>> graph;
vector<int> sz, par, dep;
int zeit;
vector<int> dis, fin, sid;
// head vertex (minimum depth) in heavy path
vector<int> head;
Hld() : n(0), rt(-1), zeit(0) {}
explicit Hld(int n_) : n(n_), rt(-1), graph(n), zeit(0) {}
void ae(int u, int v) {
assert(0 <= u); assert(u < n);
assert(0 <= v); assert(v < n);
graph[u].push_back(v);
graph[v].push_back(u);
}
void dfsSz(int u) {
sz[u] = 1;
for (const int v : graph[u]) {
auto it = std::find(graph[v].begin(), graph[v].end(), u);
if (it != graph[v].end()) graph[v].erase(it);
par[v] = u;
dep[v] = dep[u] + 1;
dfsSz(v);
sz[u] += sz[v];
}
}
void dfsHld(int u) {
dis[u] = zeit++;
const int deg = graph[u].size();
if (deg > 0) {
int vm = graph[u][0];
int jm = 0;
for (int j = 1; j < deg; ++j) {
const int v = graph[u][j];
if (sz[vm] < sz[v]) {
vm = v;
jm = j;
}
}
swap(graph[u][0], graph[u][jm]);
head[vm] = head[u];
dfsHld(vm);
for (int j = 1; j < deg; ++j) {
const int v = graph[u][j];
head[v] = v;
dfsHld(v);
}
}
fin[u] = zeit;
}
void build(int rt_) {
assert(0 <= rt_); assert(rt_ < n);
rt = rt_;
sz.assign(n, 0);
par.assign(n, -1);
dep.assign(n, -1);
dep[rt] = 0;
dfsSz(rt);
zeit = 0;
dis.assign(n, -1);
fin.assign(n, -1);
head.assign(n, -1);
head[rt] = rt;
dfsHld(rt);
assert(zeit == n);
sid.assign(n, -1);
for (int u = 0; u < n; ++u) sid[dis[u]] = u;
}
friend ostream &operator<<(ostream &os, const Hld &hld) {
const int maxDep = *max_element(hld.dep.begin(), hld.dep.end());
vector<string> ss(2 * maxDep + 1);
int pos = 0, maxPos = 0;
for (int j = 0; j < hld.n; ++j) {
const int u = hld.sid[j];
const int d = hld.dep[u];
if (hld.head[u] == u) {
if (j != 0) {
pos = maxPos + 1;
ss[2 * d - 1].resize(pos, '-');
ss[2 * d - 1] += '+';
}
} else {
ss[2 * d - 1].resize(pos, ' ');
ss[2 * d - 1] += '|';
}
ss[2 * d].resize(pos, ' ');
ss[2 * d] += std::to_string(u);
if (maxPos < static_cast<int>(ss[2 * d].size())) {
maxPos = ss[2 * d].size();
}
}
for (int d = 0; d <= 2 * maxDep; ++d) os << ss[d] << '\n';
return os;
}
bool contains(int u, int v) const {
return (dis[u] <= dis[v] && dis[v] < fin[u]);
}
int lca(int u, int v) const {
assert(0 <= u); assert(u < n);
assert(0 <= v); assert(v < n);
for (; head[u] != head[v]; ) (dis[u] > dis[v]) ? (u = par[head[u]]) : (v = par[head[v]]);
return (dis[u] > dis[v]) ? v : u;
}
int jumpUp(int u, int d) const {
assert(0 <= u); assert(u < n);
assert(d >= 0);
if (dep[u] < d) return -1;
const int tar = dep[u] - d;
for (u = head[u]; ; u = head[par[u]]) {
if (dep[u] <= tar) return sid[dis[u] + (tar - dep[u])];
}
}
int jump(int u, int v, int d) const {
assert(0 <= u); assert(u < n);
assert(0 <= v); assert(v < n);
assert(d >= 0);
const int l = lca(u, v);
const int du = dep[u] - dep[l], dv = dep[v] - dep[l];
if (d <= du) {
return jumpUp(u, d);
} else if (d <= du + dv) {
return jumpUp(v, du + dv - d);
} else {
return -1;
}
}
// [u, v) or [u, v]
template <class F> void doPathUp(int u, int v, bool inclusive, F f) const {
assert(contains(v, u));
for (; head[u] != head[v]; u = par[head[u]]) f(dis[head[u]], dis[u] + 1);
if (inclusive) {
f(dis[v], dis[u] + 1);
} else {
if (v != u) f(dis[v] + 1, dis[u] + 1);
}
}
// not path order, include lca(u, v) or not
template <class F> void doPath(int u, int v, bool inclusive, F f) const {
const int l = lca(u, v);
doPathUp(u, l, false, f);
doPathUp(v, l, inclusive, f);
}
// (vs, ps): compressed tree
// vs: DFS order (sorted by dis)
// vs[ps[x]]: the parent of vs[x]
// ids[vs[x]] = x, not set for non-tree vertex
vector<int> ids;
pair<vector<int>, vector<int>> compress(vector<int> us) {
// O(n) first time
ids.resize(n, -1);
std::sort(us.begin(), us.end(), [&](int u, int v) -> bool {
return (dis[u] < dis[v]);
});
us.erase(std::unique(us.begin(), us.end()), us.end());
int usLen = us.size();
assert(usLen >= 1);
for (int x = 1; x < usLen; ++x) us.push_back(lca(us[x - 1], us[x]));
std::sort(us.begin(), us.end(), [&](int u, int v) -> bool {
return (dis[u] < dis[v]);
});
us.erase(std::unique(us.begin(), us.end()), us.end());
usLen = us.size();
for (int x = 0; x < usLen; ++x) ids[us[x]] = x;
vector<int> ps(usLen, -1);
for (int x = 1; x < usLen; ++x) ps[x] = ids[lca(us[x - 1], us[x])];
return make_pair(us, ps);
}
};
////////////////////////////////////////////////////////////////////////////////
// iterator find_by_order(k): 0-indexed
// size_type order_of_key(key): min id s.t. >= key
#include <ext/pb_ds/assoc_container.hpp>
#include <ext/pb_ds/tree_policy.hpp>
template <class T> using rbtree = __gnu_pbds::tree<
T,
__gnu_pbds::null_type,
std::less<T>,
__gnu_pbds::rb_tree_tag,
__gnu_pbds::tree_order_statistics_node_update
>;
int N, M;
vector<int> A, B;
vector<vector<int>> G;
namespace brute {
// 0: first, nigeru; 1: second, ou
int win[2][2010][2010];
int deg[2][2010][2010];
Int run() {
vector<int> degTree(N, 0);
for (int i = 0; i < N - 1; ++i) {
++degTree[A[i]];
++degTree[B[i]];
}
memset(win, ~0, sizeof(win));
memset(deg, 0, sizeof(deg));
queue<pair<int, pair<int, int>>> que;
for (int u = 0; u < N; ++u) for (int v = 0; v < N; ++v) {
if (u == v) {
for (int t = 0; t < 2; ++t) {
win[t][u][v] = t;
que.emplace(t, make_pair(u, v));
}
} else {
deg[0][u][v] = 1 + (int)G[u].size();
deg[1][u][v] = 1 + degTree[v];
}
}
for (; !que.empty(); ) {
const int t = que.front().first;
const int u = que.front().second.first;
const int v = que.front().second.second;
que.pop();
auto reach = [&](int tt, int uu, int vv) -> void {
if (!~win[tt][uu][vv]) {
if (win[t][u][v]) {
if (!--deg[tt][uu][vv]) {
win[tt][uu][vv] = 0;
que.emplace(tt, make_pair(uu, vv));
}
} else {
win[tt][uu][vv] = 1;
que.emplace(tt, make_pair(uu, vv));
}
}
};
if (t) {
// reverse nigeru
reach(0, u, v);
for (const int i : G[u]) {
reach(0, A[i] ^ B[i] ^ u, v);
}
} else {
// reverse ou
reach(1, u, v);
for (const int i : G[v]) if (i < N - 1) {
reach(1, u, A[i] ^ B[i] ^ v);
}
}
}
for(int t=0;t<2;++t)for(int u=0;u<N;++u){cerr<<"win["<<t<<"]["<<u<<"] = ";pv(win[t][u],win[t][u]+N);}
Int ans = 0;
for (int u = 0; u < N; ++u) for (int v = 0; v < N; ++v) if (u != v) {
if (win[0][u][v]) {
++ans;
}
}
return ans;
}
} // brute
namespace one {
vector<int> par;
void dfs(int u, int p) {
par[u] = p;
for (const int i : G[u]) if (i < N - 1) {
const int v = A[i] ^ B[i] ^ u;
if (p != v) {
dfs(v, u);
}
}
}
vector<int> on;
vector<vector<int>> dss;
void DFS(int k, int u, int p, int d) {
dss[k].push_back(d);
for (const int i : G[u]) if (i < N - 1) {
const int v = A[i] ^ B[i] ^ u;
if (p != v && !on[v]) {
DFS(k, v, u, d + 1);
}
}
}
Int run() {
const int s = A[N - 1];
const int t = B[N - 1];
par.assign(N, -1);
dfs(s, -1);
vector<int> path;
for (int u = t; ~u; u = par[u]) {
path.push_back(u);
}
reverse(path.begin(), path.end());
const int len = (int)path.size() - 1;
// cerr<<"path = "<<path<<endl;
Int ans = 0;
if (len >= 3) {
on.assign(N, 0);
for (int k = 0; k <= len; ++k) {
on[path[k]] = 1;
}
dss.assign(len + 1, {});
for (int k = 0; k <= len; ++k) {
DFS(k, path[k], -1, 0);
}
// go to s
{
vector<int> bit(N, 0);
for (int k = 0; k <= len; ++k) {
for (const int d : dss[k]) bAdd(bit, k + d, +1);
for (const int d : dss[k]) ans += bSum(bit, k + d);
}
}
// go to t
{
vector<int> bit(N, 0);
for (int k = len; k >= 0; --k) {
for (const int d : dss[k]) ans += bSum(bit, (len - k) + d);
for (const int d : dss[k]) bAdd(bit, (len - k) + d, +1);
}
}
}
return ans;
}
} // one
namespace fast {
Int ans;
Hld hld;
vector<vector<int>> skip;
vector<vector<pair<int, int>>> badSkip;
vector<int> on;
vector<vector<int>> graph;
vector<int> sz, del;
void dfsSz(int u, int p) {
sz[u] = 1;
for (const int v : graph[u]) if (p != v) {
dfsSz(v, u);
sz[u] += sz[v];
}
}
string dfsString(int u, int p) {
ostringstream oss;
oss << "[" << u;
for (const int v : graph[u]) if (!del[v] && p != v) {
oss << " " << dfsString(v, u);
}
oss << "]";
return oss.str();
}
vector<int> costs;
vector<vector<int>> css[2];
Int solveBad(int jj, int u, int p) {
auto res = equal_range(css[1][jj].begin(), css[1][jj].end(), (costs[u] - 0) + 1);
Int ret = res.second - res.first;
for (const int i : G[u]) if (i < N - 1) {
const int v = A[i] ^ B[i] ^ u;
if (!on[v] && p != v) {
ret += solveBad(jj, v, u);
}
}
return ret;
}
void sub(int j, int u, int p, int p2, int d, int e) {
for (const int v : skip[u]) {
if (p2 == v) {
costs[u] = costs[p2] + 1;
} else if (on[v] == 1) {
costs[u] = 0;
}
}
css[0][j].push_back(costs[u] - d);
css[1][j].push_back(e + d);
for (const int i : G[u]) if (i < N - 1) {
const int v = A[i] ^ B[i] ^ u;
if (!on[v] && p != v) {
costs[v] = costs[u] + 1;
sub(j, v, u, p, d, e + 1);
}
}
}
void dfs(int j, int u, int p, int d) {
costs[u] = 0;
on[p] = 2;
sub(j, u, -1, -1, d, 0);
on[p] = 1;
for (const int v : graph[u]) if (!del[v] && p != v) {
dfs(j, v, u, d + 1);
}
}
void solveSubtree(int depth, int r) {
#ifdef LOCAL
cerr << string(2 * depth, ' ') << "solveSubtree " << dfsString(r, -1) << endl;
#endif
vector<int> vs;
for (const int v : graph[r]) if (!del[v]) {
vs.push_back(v);
}
sort(vs.begin(), vs.end());
const int len = vs.size();
for (int h = 0; h < 2; ++h) {
css[h].assign(len + 2, {});
}
for (int j = 0; j < len; ++j) {
dfs(j, vs[j], r, 1);
}
costs[r] = 0;
sub(len, r, -1, -1, 0, 0);
for (int h = 0; h < 2; ++h) {
for (int j = 0; j <= len; ++j) {
css[h][len + 1].insert(css[h][len + 1].end(), css[h][j].begin(), css[h][j].end());
}
for (int j = 0; j <= len + 1; ++j) {
sort(css[h][j].begin(), css[h][j].end());
}
}
Int sum = 0;
for (int j = 0; j <= len + 1; ++j) {
int pos0 = 0;
for (int pos1 = 0; pos1 < (int)css[1][j].size(); ++pos1) {
for (; pos0 < (int)css[0][j].size() && css[0][j][pos0] < css[1][j][pos1]; ++pos0) {}
sum += ((j <= len) ? -1 : +1) * pos0;
}
}
Int bad = 0;
map<int, vector<int>> jjss;
for (const auto &e : badSkip[r]) {
for (const int u : {e.first, e.second}) if (!on[u]) {
const int v = e.first ^ e.second ^ u;
auto jj = lower_bound(vs.begin(), vs.end(), v) - vs.begin();
if (jj < len && vs[jj] == v) {
// cerr<<COLOR("91")<<string(2*depth,' ')<<"bad e = "<<e<<", u = "<<u<<", jj = "<<jj<<COLOR()<<endl;
jjss[u].push_back(jj);
}
}
}
for (auto &kv : jjss) {
const int u = kv.first;
auto jjs = kv.second;
sort(jjs.begin(), jjs.end());
if (jjs[0] == jjs.back()) {
bad += solveBad(jjs[0], u, r);
}
}
#ifdef LOCAL
cerr<<string(2*depth,' ')<<"vs = "<<vs<<", costs = "<<costs<<", css = ";pv(css,css+2);
cerr<<string(2*depth,' ')<<"sum = "<<sum<<", bad = "<<bad<<endl;
#endif
ans += (sum - bad);
}
void solveRec(int depth, int u) {
for (; ; ) {
int vm = -1;
for (const int v : graph[u]) if (!del[v]) {
if (!~vm || sz[vm] < sz[v]) {
vm = v;
}
}
if (!~vm || 2 * sz[vm] <= sz[u]) {
solveSubtree(depth, u);
del[u] = 1;
for (const int v : graph[u]) if (!del[v]) {
solveRec(depth + 1, v);
}
break;
} else {
sz[u] -= sz[vm];
sz[vm] += sz[u];
u = vm;
}
}
}
void centroidDecomp(int r) {
sz.assign(N, 0);
dfsSz(r, -1);
del.assign(N, 0);
costs.assign(N, 0);
solveRec(0, r);
}
pair<rbtree<pair<int, int>> *, rbtree<pair<int, int>> *> solveSame(int u, int p, int p2, int e) {
for (const int v : skip[u]) {
if (p2 == v) {
costs[u] = costs[p2] + 1;
} else if (on[v] == 1) {
costs[u] = 0;
}
}
pair<rbtree<pair<int, int>> *, rbtree<pair<int, int>> *> ret;
ret.first = new rbtree<pair<int, int>>;
ret.second = new rbtree<pair<int, int>>;
ret.first->insert(make_pair(costs[u], u));
ret.second->insert(make_pair(e, u));
for (const int i : G[u]) if (i < N - 1) {
const int v = A[i] ^ B[i] ^ u;
if (!on[v] && p != v) {
auto res = solveSame(v, u, p, e + 1);
if (ret.first->size() < res.first->size()) {
swap(ret, res);
}
// c' < e' - e + costs[u] (?)
Int sum = 0;
for (const auto &kv : *res.second) {
const int ee = kv.first;
sum += (int)ret.first->order_of_key(make_pair(ee - e + costs[u], -1));
}
for (const auto &kv : *res.first) {
const int cc = kv.first;
sum += ((int)ret.second->size() - (int)ret.second->order_of_key(make_pair(cc - costs[u] + e + 1, -1)));
}
ans += sum;
for (const auto &kv : *res.first) {
ret.first->insert(kv);
}
for (const auto &kv : *res.second) {
ret.second->insert(kv);
}
}
}
return ret;
}
Int run() {
ans = 0;
hld = Hld(N);
for (int i = 0; i < N - 1; ++i) {
hld.ae(A[i], B[i]);
}
hld.build(0);
#ifdef LOCAL
cerr<<hld<<endl;
#endif
vector<int> tar(N, 0);
skip.assign(N, {});
badSkip.assign(N, {});
for (int i = N - 1; i < M; ++i) {
const int l = hld.lca(A[i], B[i]);
const int d = hld.dep[A[i]] + hld.dep[B[i]] - 2 * hld.dep[l];
if (d >= 3) {
tar[A[i]] = tar[B[i]] = 1;
} else if (d == 2) {
skip[A[i]].push_back(B[i]);
skip[B[i]].push_back(A[i]);
if (l != A[i] && l != B[i]) {
badSkip[l].emplace_back(A[i], B[i]);
}
}
}
on.assign(N, 0);
for (int j = N; --j >= 1; ) {
const int u = hld.sid[j];
tar[hld.par[u]] += tar[u];
}
for (int j = N; --j >= 1; ) {
const int u = hld.sid[j];
if (0 < tar[u] && tar[u] < tar[0]) {
on[hld.par[u]] = on[u] = 1;
}
}
// cerr<<"on = "<<on<<endl;
int r = -1;
for (int u = 0; u < N; ++u) if (on[u]) {
r = u;
break;
}
if (~r) {
graph.assign(N, {});
for (int i = 0; i < N - 1; ++i) if (on[A[i]] && on[B[i]]) {
graph[A[i]].push_back(B[i]);
graph[B[i]].push_back(A[i]);
}
centroidDecomp(r);
for (int u = 0; u < N; ++u) if (on[u]) {
costs[u] = 0;
solveSame(u, -1, -1, 0);
}
}
return ans;
}
} // fast
int main() {
for (; ~scanf("%d%d", &N, &M); ) {
M += (N - 1);
A.resize(M);
B.resize(M);
for (int i = 0; i < M; ++i) {
scanf("%d%d", &A[i], &B[i]);
--A[i];
--B[i];
}
G.assign(N, {});
for (int i = 0; i < M; ++i) {
G[A[i]].push_back(i);
G[B[i]].push_back(i);
}
const Int ans = fast::run();
printf("%lld\n", ans);
#ifdef LOCAL
const Int brt=brute::run();
if(brt!=ans){
cerr<<"N = "<<N<<", M-(N-1) = "<<M-(N-1)<<endl;
cerr<<"A = "<<A<<endl;
cerr<<"B = "<<B<<endl;
cerr<<"brt = "<<brt<<", ans = "<<ans<<endl;
}
assert(brt==ans);
#endif
}
return 0;
}
Details
Tip: Click on the bar to expand more detailed information
Subtask #1:
score: 10
Accepted
Test #1:
score: 10
Accepted
time: 1ms
memory: 3820kb
input:
20 3 1 2 1 3 3 4 4 5 1 6 6 7 1 8 5 9 8 10 5 11 7 12 11 13 12 14 11 15 4 16 7 17 2 18 1 19 3 20 8 20 12 4 10 1
output:
307
result:
ok 1 number(s): "307"
Test #2:
score: 0
Accepted
time: 0ms
memory: 3788kb
input:
20 4 1 2 2 3 1 4 3 5 4 6 3 7 4 8 3 9 2 10 8 11 8 12 7 13 8 14 14 15 4 16 1 17 4 18 6 19 19 20 9 13 14 2 14 13 15 6
output:
343
result:
ok 1 number(s): "343"
Test #3:
score: 0
Accepted
time: 0ms
memory: 3784kb
input:
19 4 1 2 1 3 1 4 4 5 4 6 3 7 7 8 6 9 4 10 2 11 6 12 7 13 1 14 13 15 6 16 12 17 3 18 3 19 8 12 4 6 18 5 11 9
output:
314
result:
ok 1 number(s): "314"
Test #4:
score: 0
Accepted
time: 1ms
memory: 3780kb
input:
20 3 1 2 2 3 3 4 4 5 1 6 2 7 1 8 3 9 9 10 5 11 8 12 10 13 12 14 8 15 9 16 11 17 5 18 17 19 19 20 9 19 10 15 18 15
output:
358
result:
ok 1 number(s): "358"
Test #5:
score: 0
Accepted
time: 1ms
memory: 3840kb
input:
20 6 1 2 1 3 3 4 4 5 1 6 6 7 5 8 4 9 7 10 6 11 10 12 6 13 10 14 1 15 15 16 8 17 17 18 15 19 18 20 17 2 16 3 10 1 8 7 13 5 19 7
output:
361
result:
ok 1 number(s): "361"
Test #6:
score: 0
Accepted
time: 0ms
memory: 3840kb
input:
20 8 1 2 2 3 1 4 1 5 1 6 4 7 2 8 4 9 2 10 1 11 11 12 2 13 10 14 1 15 6 16 16 17 11 18 10 19 3 20 2 6 6 7 1 18 18 13 1 20 3 12 8 4 7 1
output:
324
result:
ok 1 number(s): "324"
Subtask #2:
score: 15
Accepted
Dependency #1:
100%
Accepted
Test #7:
score: 15
Accepted
time: 1ms
memory: 3988kb
input:
300 26 1 2 1 3 2 4 4 5 3 6 6 7 5 8 2 9 1 10 10 11 6 12 8 13 6 14 10 15 6 16 4 17 9 18 10 19 5 20 18 21 6 22 10 23 18 24 1 25 19 26 17 27 8 28 10 29 25 30 16 31 27 32 13 33 4 34 5 35 12 36 9 37 15 38 32 39 29 40 11 41 5 42 28 43 1 44 25 45 27 46 3 47 34 48 27 49 9 50 39 51 20 52 48 53 10 54 35 55 23 ...
output:
86687
result:
ok 1 number(s): "86687"
Test #8:
score: 0
Accepted
time: 0ms
memory: 3976kb
input:
300 40 1 2 1 3 3 4 4 5 5 6 3 7 6 8 5 9 2 10 1 11 10 12 11 13 7 14 10 15 6 16 7 17 5 18 12 19 15 20 18 21 15 22 8 23 12 24 23 25 18 26 10 27 4 28 4 29 16 30 20 31 15 32 9 33 6 34 33 35 22 36 27 37 12 38 21 39 37 40 29 41 41 42 32 43 4 44 1 45 12 46 34 47 24 48 20 49 33 50 25 51 47 52 6 53 25 54 5 55 ...
output:
88364
result:
ok 1 number(s): "88364"
Test #9:
score: 0
Accepted
time: 1ms
memory: 3960kb
input:
299 100 1 2 1 3 1 4 3 5 3 6 4 7 1 8 6 9 5 10 8 11 1 12 2 13 11 14 3 15 8 16 14 17 11 18 2 19 3 20 10 21 3 22 17 23 23 24 16 25 7 26 5 27 12 28 8 29 7 30 29 31 23 32 1 33 1 34 29 35 7 36 5 37 6 38 19 39 22 40 21 41 5 42 29 43 19 44 38 45 23 46 21 47 29 48 27 49 28 50 47 51 25 52 28 53 9 54 45 55 52 5...
output:
88551
result:
ok 1 number(s): "88551"
Test #10:
score: 0
Accepted
time: 1ms
memory: 3992kb
input:
300 10 1 2 2 3 3 4 1 5 2 6 5 7 5 8 7 9 2 10 7 11 1 12 4 13 2 14 5 15 8 16 7 17 11 18 13 19 14 20 2 21 8 22 18 23 23 24 16 25 22 26 13 27 9 28 22 29 3 30 19 31 28 32 6 33 12 34 9 35 27 36 17 37 36 38 17 39 9 40 37 41 32 42 11 43 37 44 42 45 34 46 26 47 39 48 16 49 42 50 24 51 39 52 38 53 32 54 24 55 ...
output:
82854
result:
ok 1 number(s): "82854"
Test #11:
score: 0
Accepted
time: 0ms
memory: 4064kb
input:
300 67 1 2 2 3 3 4 1 5 5 6 4 7 6 8 4 9 5 10 4 11 10 12 2 13 8 14 9 15 3 16 4 17 5 18 12 19 1 20 17 21 6 22 4 23 18 24 18 25 14 26 20 27 7 28 26 29 2 30 14 31 20 32 6 33 30 34 29 35 19 36 33 37 12 38 7 39 35 40 9 41 3 42 42 43 33 44 27 45 25 46 7 47 5 48 24 49 47 50 23 51 19 52 41 53 19 54 1 55 27 56...
output:
88372
result:
ok 1 number(s): "88372"
Test #12:
score: 0
Accepted
time: 1ms
memory: 3996kb
input:
280 280 1 2 2 3 3 4 3 5 4 6 2 7 6 8 5 9 4 10 5 11 5 12 12 13 13 14 5 15 13 16 16 17 7 18 10 19 6 20 10 21 4 22 8 23 10 24 15 25 14 26 20 27 17 28 19 29 28 30 27 31 26 32 19 33 6 34 15 35 14 36 33 37 1 38 23 39 33 40 4 41 8 42 10 43 7 44 8 45 4 46 37 47 25 48 38 49 30 50 49 51 31 52 23 53 9 54 46 55 ...
output:
78036
result:
ok 1 number(s): "78036"
Subtask #3:
score: 15
Accepted
Dependency #2:
100%
Accepted
Test #13:
score: 15
Accepted
time: 1ms
memory: 4080kb
input:
300 26 1 2 1 3 2 4 4 5 3 6 6 7 5 8 2 9 1 10 10 11 6 12 8 13 6 14 10 15 6 16 4 17 9 18 10 19 5 20 18 21 6 22 10 23 18 24 1 25 19 26 17 27 8 28 10 29 25 30 16 31 27 32 13 33 4 34 5 35 12 36 9 37 15 38 32 39 29 40 11 41 5 42 28 43 1 44 25 45 27 46 3 47 34 48 27 49 9 50 39 51 20 52 48 53 10 54 35 55 23 ...
output:
86687
result:
ok 1 number(s): "86687"
Test #14:
score: 0
Accepted
time: 0ms
memory: 3836kb
input:
8 2 5 1 6 2 1 3 8 4 3 7 2 1 1 4 2 3 8 5
output:
34
result:
ok 1 number(s): "34"
Test #15:
score: 0
Accepted
time: 2ms
memory: 4468kb
input:
1000 80 1 2 1 3 3 4 1 5 1 6 4 7 3 8 7 9 5 10 9 11 6 12 6 13 3 14 5 15 7 16 4 17 13 18 12 19 13 20 13 21 8 22 10 23 3 24 18 25 7 26 2 27 15 28 14 29 1 30 8 31 22 32 28 33 3 34 34 35 4 36 25 37 3 38 25 39 29 40 29 41 22 42 10 43 27 44 12 45 27 46 27 47 39 48 42 49 13 50 30 51 46 52 34 53 16 54 49 55 1...
output:
988373
result:
ok 1 number(s): "988373"
Test #16:
score: 0
Accepted
time: 0ms
memory: 5292kb
input:
2000 40 1 2 2 3 1 4 4 5 5 6 1 7 7 8 3 9 7 10 3 11 7 12 12 13 3 14 2 15 15 16 16 17 4 18 3 19 18 20 17 21 1 22 17 23 7 24 16 25 6 26 14 27 12 28 13 29 15 30 13 31 30 32 30 33 33 34 28 35 22 36 9 37 7 38 10 39 12 40 5 41 26 42 10 43 27 44 1 45 18 46 34 47 26 48 47 49 24 50 34 51 37 52 28 53 15 54 32 5...
output:
3822427
result:
ok 1 number(s): "3822427"
Test #17:
score: 0
Accepted
time: 4ms
memory: 5396kb
input:
2000 10 1 2 1 3 1 4 3 5 1 6 6 7 4 8 2 9 1 10 6 11 3 12 9 13 13 14 14 15 12 16 14 17 15 18 15 19 16 20 13 21 4 22 9 23 2 24 4 25 1 26 13 27 7 28 20 29 4 30 9 31 14 32 14 33 8 34 5 35 18 36 31 37 11 38 37 39 17 40 20 41 40 42 29 43 24 44 21 45 15 46 38 47 1 48 47 49 35 50 32 51 26 52 9 53 14 54 25 55 ...
output:
3501231
result:
ok 1 number(s): "3501231"
Test #18:
score: 0
Accepted
time: 3ms
memory: 5144kb
input:
2000 200 1 2 2 3 1 4 3 5 2 6 4 7 2 8 1 9 4 10 9 11 9 12 8 13 10 14 9 15 6 16 5 17 5 18 4 19 3 20 11 21 14 22 13 23 20 24 15 25 24 26 19 27 16 28 23 29 28 30 30 31 16 32 5 33 20 34 1 35 9 36 5 37 30 38 15 39 6 40 40 41 31 42 25 43 28 44 42 45 2 46 7 47 34 48 2 49 35 50 42 51 28 52 38 53 35 54 51 55 2...
output:
3970625
result:
ok 1 number(s): "3970625"
Test #19:
score: 0
Accepted
time: 5ms
memory: 5068kb
input:
1998 1996 1 2 2 3 3 4 1 5 1 6 6 7 7 8 8 9 2 10 4 11 8 12 12 13 7 14 4 15 13 16 16 17 3 18 14 19 10 20 7 21 9 22 16 23 13 24 21 25 18 26 18 27 11 28 27 29 16 30 12 31 13 32 12 33 29 34 27 35 1 36 29 37 3 38 14 39 26 40 11 41 21 42 27 43 35 44 17 45 20 46 43 47 23 48 39 49 30 50 27 51 46 52 11 53 29 5...
output:
3989549
result:
ok 1 number(s): "3989549"
Test #20:
score: 0
Accepted
time: 2ms
memory: 5552kb
input:
1999 3 1 2 1 3 3 4 4 5 4 6 5 7 4 8 2 9 9 10 9 11 8 12 5 13 9 14 8 15 14 16 12 17 5 18 3 19 15 20 12 21 15 22 17 23 18 24 11 25 21 26 17 27 1 28 10 29 25 30 7 31 21 32 31 33 5 34 7 35 26 36 29 37 33 38 11 39 10 40 25 41 39 42 8 43 6 44 24 45 5 46 45 47 21 48 30 49 6 50 35 51 27 52 23 53 41 54 36 55 1...
output:
2959137
result:
ok 1 number(s): "2959137"
Subtask #4:
score: 20
Accepted
Dependency #3:
100%
Accepted
Test #21:
score: 20
Accepted
time: 1ms
memory: 3768kb
input:
8 2 5 1 6 2 1 3 8 4 3 7 2 1 1 4 2 3 8 5
output:
34
result:
ok 1 number(s): "34"
Test #22:
score: 0
Accepted
time: 52ms
memory: 32876kb
input:
40000 1000 1 2 1 3 3 4 3 5 3 6 1 7 3 8 6 9 9 10 2 11 3 12 7 13 12 14 8 15 13 16 5 17 11 18 15 19 1 20 12 21 11 22 15 23 10 24 12 25 12 26 3 27 3 28 28 29 24 30 29 31 23 32 1 33 21 34 14 35 23 36 3 37 34 38 12 39 24 40 25 41 40 42 27 43 9 44 31 45 35 46 31 47 18 48 21 49 44 50 48 51 2 52 44 53 18 54 ...
output:
1595797221
result:
ok 1 number(s): "1595797221"
Test #23:
score: 0
Accepted
time: 83ms
memory: 28936kb
input:
40000 34000 1 2 1 3 2 4 3 5 2 6 5 7 2 8 7 9 9 10 5 11 11 12 4 13 11 14 2 15 10 16 14 17 15 18 16 19 13 20 11 21 19 22 22 23 10 24 3 25 21 26 21 27 24 28 1 29 7 30 22 31 8 32 12 33 24 34 26 35 14 36 5 37 4 38 9 39 16 40 5 41 35 42 27 43 20 44 24 45 26 46 27 47 32 48 8 49 43 50 42 51 27 52 37 53 3 54 ...
output:
1599943090
result:
ok 1 number(s): "1599943090"
Test #24:
score: 0
Accepted
time: 72ms
memory: 41864kb
input:
39998 8 1 2 2 3 1 4 3 5 3 6 1 7 7 8 8 9 8 10 4 11 4 12 11 13 8 14 11 15 12 16 6 17 1 18 17 19 6 20 11 21 10 22 22 23 17 24 11 25 3 26 6 27 6 28 12 29 6 30 24 31 12 32 22 33 8 34 31 35 15 36 25 37 20 38 25 39 24 40 9 41 38 42 2 43 32 44 25 45 27 46 21 47 36 48 44 49 7 50 3 51 37 52 35 53 34 54 22 55 ...
output:
1329770016
result:
ok 1 number(s): "1329770016"
Test #25:
score: 0
Accepted
time: 57ms
memory: 36832kb
input:
39999 100 1 2 1 3 1 4 2 5 3 6 5 7 3 8 7 9 9 10 9 11 4 12 2 13 5 14 7 15 12 16 7 17 11 18 14 19 5 20 8 21 8 22 14 23 8 24 20 25 19 26 25 27 16 28 25 29 20 30 12 31 19 32 32 33 22 34 8 35 33 36 1 37 25 38 4 39 5 40 24 41 39 42 21 43 17 44 6 45 5 46 25 47 14 48 24 49 1 50 45 51 20 52 27 53 2 54 53 55 1...
output:
1552570727
result:
ok 1 number(s): "1552570727"
Test #26:
score: 0
Accepted
time: 71ms
memory: 32496kb
input:
40000 90 1 2 2 3 3 4 4 5 5 6 6 7 7 8 8 9 9 10 10 11 11 12 12 13 13 14 14 15 15 16 16 17 17 18 18 19 19 20 20 21 21 22 22 23 23 24 24 25 25 26 26 27 27 28 28 29 29 30 30 31 31 32 32 33 33 34 34 35 35 36 36 37 37 38 38 39 39 40 40 41 41 42 42 43 43 44 44 45 45 46 46 47 47 48 48 49 49 50 50 51 51 52 52...
output:
1599720848
result:
ok 1 number(s): "1599720848"
Test #27:
score: 0
Accepted
time: 44ms
memory: 31760kb
input:
39998 20000 1 2 1 3 1 4 1 5 1 6 1 7 1 8 1 9 8 10 1 11 1 12 1 13 1 14 1 15 10 16 1 17 1 18 1 19 1 20 1 21 10 22 1 23 1 24 1 25 1 26 1 27 1 28 1 29 26 30 1 31 29 32 1 33 1 34 12 35 25 36 1 37 1 38 1 39 1 40 1 41 1 42 1 43 13 44 1 45 1 46 15 47 1 48 26 49 1 50 18 51 1 52 1 53 1 54 1 55 1 56 43 57 1 58 ...
output:
953273251
result:
ok 1 number(s): "953273251"
Test #28:
score: 0
Accepted
time: 31ms
memory: 32404kb
input:
40000 2 2 1 3 2 4 3 5 2 6 5 7 6 8 7 9 1 10 1 11 1 12 1 13 1 14 1 15 1 16 1 17 1 18 1 19 1 20 1 21 1 22 1 23 1 24 1 25 1 26 1 27 1 28 1 29 1 30 1 31 1 32 1 33 1 34 1 35 1 36 1 37 1 38 1 39 1 40 1 41 1 42 1 43 1 44 1 45 1 46 1 47 1 48 1 49 1 50 1 51 1 52 1 53 1 54 1 55 1 56 1 57 1 58 1 59 1 60 1 61 1 ...
output:
359967
result:
ok 1 number(s): "359967"
Subtask #5:
score: 10
Accepted
Test #29:
score: 10
Accepted
time: 31ms
memory: 23252kb
input:
98765 1 2 1 3 1 4 2 5 2 6 5 7 4 8 6 9 7 10 7 11 6 12 1 13 11 14 13 15 7 16 6 17 14 18 4 19 13 20 14 21 11 22 21 23 1 24 13 25 7 26 16 27 8 28 21 29 20 30 10 31 12 32 10 33 7 34 31 35 29 36 29 37 30 38 34 39 38 40 14 41 40 42 26 43 33 44 1 45 44 46 25 47 14 48 2 49 30 50 26 51 46 52 34 53 32 54 31 55...
output:
0
result:
ok 1 number(s): "0"
Test #30:
score: 0
Accepted
time: 27ms
memory: 23332kb
input:
99824 1 2 1 3 1 4 1 5 1 6 2 7 2 8 1 9 3 10 9 11 4 12 6 13 6 14 2 15 3 16 9 17 13 18 15 19 4 20 13 21 12 22 15 23 5 24 16 25 17 26 9 27 26 28 18 29 8 30 23 31 5 32 31 33 28 34 5 35 11 36 20 37 6 38 36 39 35 40 4 41 11 42 10 43 12 44 28 45 15 46 38 47 9 48 36 49 16 50 45 51 49 52 44 53 6 54 12 55 5 56...
output:
0
result:
ok 1 number(s): "0"
Test #31:
score: 0
Accepted
time: 190ms
memory: 79216kb
input:
67765 1 2 1 3 2 4 1 5 2 6 2 7 3 8 4 9 3 10 5 11 6 12 4 13 7 14 13 15 11 16 11 17 3 18 8 19 2 20 13 21 19 22 7 23 14 24 7 25 6 26 21 27 1 28 1 29 2 30 16 31 9 32 31 33 26 34 1 35 21 36 10 37 32 38 16 39 38 40 10 41 20 42 23 43 8 44 10 45 14 46 42 47 12 48 17 49 45 50 28 51 42 52 49 53 44 54 9 55 8 56...
output:
2254349415
result:
ok 1 number(s): "2254349415"
Test #32:
score: 0
Accepted
time: 245ms
memory: 115736kb
input:
100000 1 2 1 3 1 4 3 5 4 6 2 7 1 8 2 9 5 10 3 11 9 12 10 13 3 14 12 15 13 16 11 17 8 18 14 19 8 20 16 21 7 22 18 23 19 24 21 25 5 26 10 27 22 28 21 29 8 30 17 31 10 32 30 33 7 34 22 35 13 36 30 37 8 38 20 39 23 40 11 41 17 42 35 43 2 44 13 45 17 46 37 47 4 48 37 49 11 50 26 51 45 52 45 53 18 54 44 5...
output:
4706707961
result:
ok 1 number(s): "4706707961"
Subtask #6:
score: 30
Accepted
Dependency #1:
100%
Accepted
Dependency #2:
100%
Accepted
Dependency #3:
100%
Accepted
Dependency #4:
100%
Accepted
Dependency #5:
100%
Accepted
Test #33:
score: 30
Accepted
time: 110ms
memory: 76128kb
input:
100000 2 2 1 3 2 4 3 5 2 6 5 7 6 8 7 9 1 10 1 11 1 12 1 13 1 14 1 15 1 16 1 17 1 18 1 19 1 20 1 21 1 22 1 23 1 24 1 25 1 26 1 27 1 28 1 29 1 30 1 31 1 32 1 33 1 34 1 35 1 36 1 37 1 38 1 39 1 40 1 41 1 42 1 43 1 44 1 45 1 46 1 47 1 48 1 49 1 50 1 51 1 52 1 53 1 54 1 55 1 56 1 57 1 58 1 59 1 60 1 61 1...
output:
899967
result:
ok 1 number(s): "899967"
Test #34:
score: 0
Accepted
time: 1ms
memory: 3816kb
input:
8 2 5 1 6 2 1 3 8 4 3 7 2 1 1 4 2 3 8 5
output:
34
result:
ok 1 number(s): "34"
Test #35:
score: 0
Accepted
time: 0ms
memory: 3980kb
input:
300 26 1 2 1 3 2 4 4 5 3 6 6 7 5 8 2 9 1 10 10 11 6 12 8 13 6 14 10 15 6 16 4 17 9 18 10 19 5 20 18 21 6 22 10 23 18 24 1 25 19 26 17 27 8 28 10 29 25 30 16 31 27 32 13 33 4 34 5 35 12 36 9 37 15 38 32 39 29 40 11 41 5 42 28 43 1 44 25 45 27 46 3 47 34 48 27 49 9 50 39 51 20 52 48 53 10 54 35 55 23 ...
output:
86687
result:
ok 1 number(s): "86687"
Test #36:
score: 0
Accepted
time: 42ms
memory: 23536kb
input:
99999 1 2 1 3 2 4 3 5 2 6 1 7 1 8 4 9 2 10 2 11 7 12 10 13 4 14 9 15 9 16 9 17 15 18 7 19 10 20 13 21 9 22 11 23 3 24 13 25 7 26 8 27 6 28 19 29 21 30 14 31 2 32 12 33 22 34 32 35 14 36 7 37 4 38 1 39 8 40 34 41 10 42 8 43 34 44 39 45 22 46 36 47 34 48 2 49 31 50 27 51 46 52 47 53 49 54 3 55 25 56 3...
output:
0
result:
ok 1 number(s): "0"
Test #37:
score: 0
Accepted
time: 198ms
memory: 77900kb
input:
100000 400 2 1 3 2 4 3 5 4 6 5 7 6 8 7 9 8 10 4 11 10 12 11 13 12 14 13 15 14 16 15 17 16 18 17 19 11 20 19 21 2 22 21 23 22 24 23 25 24 26 25 27 26 28 27 29 28 30 29 31 30 32 31 33 32 34 23 35 34 36 35 37 36 38 37 39 38 40 39 41 40 42 41 43 19 44 43 45 44 46 45 47 46 48 47 49 48 50 49 51 50 52 51 5...
output:
9933452098
result:
ok 1 number(s): "9933452098"
Test #38:
score: 0
Accepted
time: 110ms
memory: 75720kb
input:
99998 10000 2 1 3 1 4 1 5 1 6 1 7 1 8 5 9 1 10 1 11 1 12 1 13 1 14 1 15 2 16 1 17 1 18 1 19 1 20 1 21 1 22 2 23 1 24 7 25 1 26 1 27 1 28 1 29 1 30 1 31 1 32 1 33 1 34 1 35 1 36 1 37 1 38 1 39 1 40 1 41 1 42 1 43 1 44 1 45 1 46 1 47 1 48 1 49 1 50 1 51 1 52 1 53 1 54 1 55 1 56 1 57 1 58 1 59 44 60 1 ...
output:
2147621794
result:
ok 1 number(s): "2147621794"
Test #39:
score: 0
Accepted
time: 250ms
memory: 103384kb
input:
100000 10 2 1 3 1 4 3 5 1 6 5 7 4 8 2 9 2 10 5 11 2 12 11 13 6 14 11 15 1 16 5 17 13 18 14 19 12 20 8 21 16 22 3 23 10 24 2 25 5 26 24 27 8 28 11 29 12 30 6 31 21 32 4 33 19 34 29 35 31 36 15 37 31 38 1 39 17 40 33 41 34 42 15 43 3 44 39 45 10 46 40 47 1 48 18 49 25 50 42 51 13 52 40 53 4 54 3 55 38...
output:
8473241803
result:
ok 1 number(s): "8473241803"
Test #40:
score: 0
Accepted
time: 211ms
memory: 87008kb
input:
100000 300 2 1 3 1 4 1 5 2 6 3 7 1 8 3 9 1 10 8 11 1 12 8 13 7 14 13 15 8 16 10 17 8 18 4 19 18 20 12 21 8 22 18 23 11 24 22 25 14 26 4 27 25 28 11 29 28 30 1 31 2 32 30 33 27 34 5 35 17 36 19 37 13 38 27 39 13 40 36 41 26 42 21 43 14 44 42 45 29 46 45 47 18 48 8 49 34 50 9 51 21 52 34 53 50 54 39 5...
output:
9874396013
result:
ok 1 number(s): "9874396013"
Test #41:
score: 0
Accepted
time: 200ms
memory: 76408kb
input:
100000 3000 2 1 3 2 4 3 5 1 6 1 7 3 8 6 9 7 10 5 11 7 12 10 13 4 14 13 15 12 16 14 17 9 18 5 19 9 20 16 21 16 22 12 23 5 24 5 25 20 26 14 27 10 28 15 29 4 30 16 31 29 32 1 33 8 34 13 35 12 36 19 37 33 38 33 39 24 40 16 41 38 42 27 43 23 44 10 45 9 46 11 47 26 48 21 49 16 50 24 51 11 52 35 53 36 54 1...
output:
9993648157
result:
ok 1 number(s): "9993648157"
Test #42:
score: 0
Accepted
time: 216ms
memory: 67316kb
input:
100000 50000 2 1 3 1 4 2 5 4 6 5 7 1 8 2 9 8 10 5 11 10 12 10 13 9 14 2 15 2 16 15 17 12 18 2 19 2 20 3 21 7 22 11 23 7 24 2 25 11 26 5 27 25 28 20 29 17 30 27 31 11 32 18 33 14 34 8 35 23 36 8 37 33 38 30 39 7 40 39 41 3 42 38 43 4 44 19 45 2 46 13 47 26 48 4 49 20 50 32 51 39 52 6 53 40 54 11 55 3...
output:
9999784987
result:
ok 1 number(s): "9999784987"
Test #43:
score: 0
Accepted
time: 238ms
memory: 66564kb
input:
99998 99999 2 1 3 1 4 3 5 2 6 3 7 3 8 1 9 1 10 7 11 5 12 3 13 8 14 11 15 14 16 10 17 3 18 17 19 13 20 17 21 8 22 12 23 19 24 9 25 14 26 13 27 9 28 5 29 22 30 3 31 17 32 28 33 4 34 14 35 10 36 7 37 3 38 26 39 34 40 29 41 4 42 10 43 41 44 33 45 39 46 25 47 3 48 11 49 18 50 9 51 40 52 33 53 4 54 8 55 2...
output:
9999471735
result:
ok 1 number(s): "9999471735"