提交时间:2023-04-14 21:24:43

运行 ID: 74760

#include<bits/stdc++.h> using namespace std; #define int long long int v[114514]; int t[114][514]; int dp[114514]; int main(){ int n; cin>>n; for(int i=1;i<=n;i++)cin>>v[i]; for(int i=1;i<=n;i++){ cin>>t[i][0]; char a=getchar();int tot=1; while(a!='\n'){ cin>>t[i][tot++]; a=getchar(); } }//读入 dp[1]=v[1];//初始化 for(int i=1;i<=n;i++){ int j=1; dp[i]=max(dp[i],v[i]); while(t[i][j]){//遍历这个点能到达的点 dp[t[i][j]]=max(dp[t[i][j]],dp[i]+v[t[i][j]]);//更新 j++; } // cout<<"-"; // for(int i=1;i<=n;i++) // cout<<dp[i]<<" "; // cout<<endl; //调试 } cout<<dp[n]; }