QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#216555 | #7578. Salty Fish | SolitaryDream# | RE | 0ms | 39736kb | C++17 | 2.0kb | 2023-10-15 19:47:29 | 2023-10-15 19:47:29 |
Judging History
answer
#include<bits/stdc++.h>
using namespace std;
#define FOR(i,s,t) for(int i=(s),_t=(t); i<=_t; ++i)
#define DOR(i,s,t) for(int i=(s),_t=(t); i>=_t; --i)
typedef long long ll;
const int N=6e5+50;
vector<int> E[N];
vector<pair<int,int>> G[N];
int a[N];
int dep[N],mx[N];
int son[N];
int n,m,tid;
int pos[N];
ll f[N];
void dfs(int x,int fr) {
dep[x]=dep[fr]+1;
mx[x]=0;
son[x]=0;
for(auto y: E[x]) {
dfs(y,x);
if(mx[y]+1>mx[x]) {
mx[x]=mx[y]+1;
son[x]=y;
}
}
}
void rdfs(int x) {
pos[x]=++tid;
if(son[x]) rdfs(son[x]);
for(auto y: E[x]) if(y!=son[x]) {
++tid;
rdfs(y);
}
}
void sol(int x) {
for(auto y: E[x]) sol(y);
for(auto y: E[x]) if(y!=son[x]) {
FOR(i,-1,mx[y]) {
f[pos[x]+1+i]+=f[pos[y]+i];
}
}
f[pos[x]-1]=f[pos[x]]+a[x];
auto &v=G[x];
v.push_back({-1,0});
for(auto &[d,c]: v) d=min(d,mx[x]);
sort(v.begin(),v.end());
if(!v.size()) return ;
ll e=0,w=0;
DOR(i,v.size()-1,1) {
w=max(w,-e+f[pos[x]+v[i].first]);
e+=v[i].second;
FOR(j,v[i-1].first,v[i].first-2) {
if(f[pos[x]+j]<f[pos[x]+j+1]) {
cerr << "Failed !!" << endl;
assert(0);
}
}
FOR(j,v[i-1].first,v[i].first-1) {
f[pos[x]+j]=max(f[pos[x]+j]-e,w);
}
}
}
void solve() {
cin >> n >> m;
FOR(i,1,n) E[i].clear(),G[i].clear();
FOR(i,2,n) {
int x;
cin >> x;
E[x].push_back(i);
}
FOR(i,1,n) cin >> a[i];
FOR(i,1,m) {
int x,d,c;
cin >> x >> d >> c;
G[x].push_back({d,c});
}
dfs(1,0);
tid=0;
++tid;
rdfs(1);
FOR(i,1,tid) f[i]=0;
sol(1);
cout << f[pos[1]-1] << '\n';
}
int main() {
ios::sync_with_stdio(false);
cin.tie(nullptr);
int T;
cin >> T;
while(T--) solve();
return 0;
}
详细
Test #1:
score: 100
Accepted
time: 0ms
memory: 39736kb
input:
1 6 3 1 1 2 2 3 2 5 4 3 3 2 2 1 3 3 1 7 1 2 4
output:
6
result:
ok 1 number(s): "6"
Test #2:
score: -100
Runtime Error
input:
1003 100 100 1 2 3 4 5 6 7 8 9 10 6 1 2 4 1 11 17 14 17 2 13 8 8 5 11 7 18 6 2 10 23 11 13 3 9 1 33 20 3 9 32 35 11 41 42 29 33 45 21 35 9 36 12 54 19 24 57 31 32 5 3 10 46 15 46 48 20 44 5 41 67 7 18 30 27 6 29 69 57 75 62 74 18 64 17 21 38 60 79 69 54 90 83 83 31 96 31 93 53 152 498 653 559 287 38...
output:
19856