# |
Submission time |
Handle |
Problem |
Language |
Result |
Execution time |
Memory |
791659 |
2023-07-24T08:38:46 Z |
GEN 이지후(#10078) |
Nestabilnost (COI23_nestabilnost) |
C++17 |
|
1500 ms |
96592 KB |
#include <bits/stdc++.h>
using namespace std;
using lint = long long;
using pi = array<lint, 2>;
#define sz(v) ((int)(v).size())
#define all(v) (v).begin(), (v).end()
const int MAXN = 300005;
int a[MAXN], f[MAXN], sm[MAXN], par[MAXN];
int root[MAXN];
vector<int> gph[MAXN];
void dfs(int x, int p) {
if (p == -1)
root[x] = 1, par[x] = -1;
for (auto &y : gph[x]) {
if (y != p) {
if (a[y] <= a[x] && a[y] > 0)
root[y] = 1;
if (a[y] > a[x] + 1)
root[y] = 1;
par[y] = x;
dfs(y, x);
}
}
}
struct node {
int val;
int canGeq;
lint cost;
lint eval() { return cost + (canGeq ? sm[val] : f[val]); }
bool operator<(const node &nd) const { return val < nd.val; }
};
vector<node> solve(int x, int p) {
vector<vector<node>> aggr;
for (auto &y : gph[x]) {
if (y != p && !root[y]) {
auto v = solve(y, x);
if (a[x] + 1 == a[y]) {
lint totmin = 1e18;
for (auto &x : v)
totmin = min(totmin, x.eval());
v.push_back({0, 1, totmin});
} else {
lint costEq = 1e18;
lint totmin = 1e18;
for (auto &foo : v) {
if (foo.val == a[x] + 1 || (foo.val <= a[x] + 1 && foo.canGeq)) {
costEq = min(costEq, foo.cost);
}
totmin = min(totmin, foo.eval());
}
v.clear();
v.push_back({0, 1, totmin});
v.push_back({a[x] + 1, 0, costEq});
// k = a[x] + 1 or k >= 0
}
aggr.push_back(v);
}
}
if (sz(aggr) == 0) {
vector<node> ret;
ret.push_back({a[x] + 1, 1, 0});
return ret;
}
vector<node> ret;
// generate geqs
{
vector<lint> costPoses(sz(aggr), 1e18);
vector<array<lint, 3>> upd;
for (int i = 0; i < sz(aggr); i++) {
for (auto &y : aggr[i]) {
if (y.canGeq) {
upd.push_back({max(y.val, a[x] + 1), y.cost, i});
}
}
}
int toolarge = sz(aggr);
sort(all(upd));
lint t1 = 1e17;
lint sum = 0;
for (int i = 0; i < sz(upd);) {
int j = i;
while (j < sz(upd) && upd[j][0] == upd[i][0])
j++;
for (int k = i; k < j; k++) {
if (costPoses[upd[k][2]] > 5e17) {
toolarge--;
sum += upd[k][1];
} else {
if (costPoses[upd[k][2]] > upd[k][1]) {
sum += upd[k][1] - costPoses[upd[k][2]];
}
}
costPoses[upd[k][2]] = min(costPoses[upd[k][2]], upd[k][1]);
}
if (toolarge) {
i = j;
continue;
}
if (t1 > sum) {
t1 = sum;
ret.push_back({(int)upd[i][0], 1, t1});
}
i = j;
}
}
// generate eqs (mutate if u like it)
{
vector<int> coords;
for (auto &v : aggr) {
sort(all(v));
lint prefix = 1e18;
for (auto &y : v) {
if (y.canGeq == 0 && y.val > a[x])
coords.push_back(y.val);
if (y.canGeq) {
prefix = min(prefix, y.cost);
y.cost = prefix;
}
}
}
sort(all(coords));
coords.resize(unique(all(coords)) - coords.begin());
for (auto &x : coords) {
lint tot = 0;
for (auto &v : aggr) {
int pos = upper_bound(all(v), (node){x, 0, 0}) - v.begin();
lint minv = 1e18;
for (int j = pos - 1; j >= max(0, pos - 3); j--) {
if (v[j].canGeq)
minv = min(minv, v[j].cost);
else if (!v[j].canGeq && v[j].val == x)
minv = min(minv, v[j].cost);
}
tot += minv;
if (tot > 2e17) {
break;
}
}
if (tot < 1e17)
ret.push_back({x, 0, tot});
}
}
return ret;
}
int main() {
ios_base::sync_with_stdio(0);
cin.tie(0);
cout.tie(0);
int n;
cin >> n;
for (int i = 0; i < n; i++)
cin >> a[i];
for (int i = 1; i <= n; i++) {
cin >> f[i];
}
sm[n + 1] = 1e9;
for (int i = n; i; i--) {
sm[i] = min(sm[i + 1], f[i]);
}
for (int i = 0; i < n - 1; i++) {
int u, v;
cin >> u >> v;
u--;
v--;
gph[u].push_back(v);
gph[v].push_back(u);
}
dfs(0, -1);
lint ans = 0;
for (int i = 0; i < n; i++) {
if (root[i]) {
auto foo = solve(i, par[i]);
lint tot = 1e18;
for (auto &x : foo)
tot = min(tot, x.eval());
ans += tot;
}
}
cout << ans << "\n";
}
# |
Verdict |
Execution time |
Memory |
Grader output |
1 |
Correct |
7 ms |
8788 KB |
Output is correct |
2 |
Correct |
8 ms |
8788 KB |
Output is correct |
3 |
Correct |
7 ms |
8788 KB |
Output is correct |
4 |
Correct |
6 ms |
8788 KB |
Output is correct |
5 |
Correct |
8 ms |
7892 KB |
Output is correct |
6 |
Correct |
7 ms |
7892 KB |
Output is correct |
# |
Verdict |
Execution time |
Memory |
Grader output |
1 |
Correct |
198 ms |
96592 KB |
Output is correct |
2 |
Correct |
214 ms |
96524 KB |
Output is correct |
3 |
Correct |
228 ms |
96592 KB |
Output is correct |
4 |
Correct |
219 ms |
96588 KB |
Output is correct |
5 |
Correct |
219 ms |
96588 KB |
Output is correct |
6 |
Correct |
183 ms |
40260 KB |
Output is correct |
7 |
Correct |
184 ms |
40568 KB |
Output is correct |
8 |
Correct |
177 ms |
41384 KB |
Output is correct |
9 |
Correct |
177 ms |
41396 KB |
Output is correct |
# |
Verdict |
Execution time |
Memory |
Grader output |
1 |
Correct |
3 ms |
7380 KB |
Output is correct |
2 |
Correct |
3 ms |
7380 KB |
Output is correct |
3 |
Correct |
3 ms |
7380 KB |
Output is correct |
4 |
Correct |
3 ms |
7380 KB |
Output is correct |
5 |
Correct |
3 ms |
7380 KB |
Output is correct |
6 |
Correct |
3 ms |
7380 KB |
Output is correct |
7 |
Correct |
3 ms |
7380 KB |
Output is correct |
# |
Verdict |
Execution time |
Memory |
Grader output |
1 |
Correct |
7 ms |
8788 KB |
Output is correct |
2 |
Correct |
8 ms |
8788 KB |
Output is correct |
3 |
Correct |
7 ms |
8788 KB |
Output is correct |
4 |
Correct |
6 ms |
8788 KB |
Output is correct |
5 |
Correct |
8 ms |
7892 KB |
Output is correct |
6 |
Correct |
7 ms |
7892 KB |
Output is correct |
7 |
Correct |
3 ms |
7380 KB |
Output is correct |
8 |
Correct |
3 ms |
7380 KB |
Output is correct |
9 |
Correct |
3 ms |
7380 KB |
Output is correct |
10 |
Correct |
3 ms |
7380 KB |
Output is correct |
11 |
Correct |
3 ms |
7380 KB |
Output is correct |
12 |
Correct |
3 ms |
7380 KB |
Output is correct |
13 |
Correct |
3 ms |
7380 KB |
Output is correct |
14 |
Correct |
6 ms |
7648 KB |
Output is correct |
15 |
Correct |
6 ms |
7636 KB |
Output is correct |
16 |
Correct |
6 ms |
7648 KB |
Output is correct |
17 |
Correct |
7 ms |
7636 KB |
Output is correct |
18 |
Correct |
6 ms |
7636 KB |
Output is correct |
19 |
Correct |
7 ms |
7636 KB |
Output is correct |
20 |
Correct |
6 ms |
7636 KB |
Output is correct |
21 |
Correct |
6 ms |
7652 KB |
Output is correct |
22 |
Correct |
7 ms |
7640 KB |
Output is correct |
23 |
Correct |
6 ms |
7636 KB |
Output is correct |
24 |
Correct |
24 ms |
7888 KB |
Output is correct |
25 |
Correct |
24 ms |
7884 KB |
Output is correct |
26 |
Correct |
34 ms |
7932 KB |
Output is correct |
27 |
Correct |
48 ms |
7892 KB |
Output is correct |
# |
Verdict |
Execution time |
Memory |
Grader output |
1 |
Correct |
7 ms |
8788 KB |
Output is correct |
2 |
Correct |
8 ms |
8788 KB |
Output is correct |
3 |
Correct |
7 ms |
8788 KB |
Output is correct |
4 |
Correct |
6 ms |
8788 KB |
Output is correct |
5 |
Correct |
8 ms |
7892 KB |
Output is correct |
6 |
Correct |
7 ms |
7892 KB |
Output is correct |
7 |
Correct |
198 ms |
96592 KB |
Output is correct |
8 |
Correct |
214 ms |
96524 KB |
Output is correct |
9 |
Correct |
228 ms |
96592 KB |
Output is correct |
10 |
Correct |
219 ms |
96588 KB |
Output is correct |
11 |
Correct |
219 ms |
96588 KB |
Output is correct |
12 |
Correct |
183 ms |
40260 KB |
Output is correct |
13 |
Correct |
184 ms |
40568 KB |
Output is correct |
14 |
Correct |
177 ms |
41384 KB |
Output is correct |
15 |
Correct |
177 ms |
41396 KB |
Output is correct |
16 |
Correct |
3 ms |
7380 KB |
Output is correct |
17 |
Correct |
3 ms |
7380 KB |
Output is correct |
18 |
Correct |
3 ms |
7380 KB |
Output is correct |
19 |
Correct |
3 ms |
7380 KB |
Output is correct |
20 |
Correct |
3 ms |
7380 KB |
Output is correct |
21 |
Correct |
3 ms |
7380 KB |
Output is correct |
22 |
Correct |
3 ms |
7380 KB |
Output is correct |
23 |
Correct |
6 ms |
7648 KB |
Output is correct |
24 |
Correct |
6 ms |
7636 KB |
Output is correct |
25 |
Correct |
6 ms |
7648 KB |
Output is correct |
26 |
Correct |
7 ms |
7636 KB |
Output is correct |
27 |
Correct |
6 ms |
7636 KB |
Output is correct |
28 |
Correct |
7 ms |
7636 KB |
Output is correct |
29 |
Correct |
6 ms |
7636 KB |
Output is correct |
30 |
Correct |
6 ms |
7652 KB |
Output is correct |
31 |
Correct |
7 ms |
7640 KB |
Output is correct |
32 |
Correct |
6 ms |
7636 KB |
Output is correct |
33 |
Correct |
24 ms |
7888 KB |
Output is correct |
34 |
Correct |
24 ms |
7884 KB |
Output is correct |
35 |
Correct |
34 ms |
7932 KB |
Output is correct |
36 |
Correct |
48 ms |
7892 KB |
Output is correct |
37 |
Correct |
317 ms |
21700 KB |
Output is correct |
38 |
Correct |
306 ms |
21800 KB |
Output is correct |
39 |
Correct |
334 ms |
21784 KB |
Output is correct |
40 |
Correct |
299 ms |
21944 KB |
Output is correct |
41 |
Correct |
272 ms |
21748 KB |
Output is correct |
42 |
Correct |
282 ms |
21836 KB |
Output is correct |
43 |
Correct |
346 ms |
22268 KB |
Output is correct |
44 |
Correct |
265 ms |
23764 KB |
Output is correct |
45 |
Correct |
303 ms |
27688 KB |
Output is correct |
46 |
Correct |
208 ms |
22520 KB |
Output is correct |
47 |
Correct |
339 ms |
22788 KB |
Output is correct |
48 |
Correct |
213 ms |
22856 KB |
Output is correct |
49 |
Correct |
215 ms |
22920 KB |
Output is correct |
50 |
Execution timed out |
1581 ms |
33816 KB |
Time limit exceeded |
51 |
Halted |
0 ms |
0 KB |
- |