提交时间:2023-04-18 14:03:43
运行 ID: 75087
#include<bits/stdc++.h> using namespace std; #define int long long int v[1000000]; int t[1000][1000]; int dp[1000000]; signed main(){ int n; cin>>n; for(int i=1;i<=n;i++)cin>>v[i]; string a; getline(cin, a); for(int i=1;i<=n;i++){ getline(cin, a); int tot=0,x=0; for(int j=1;j<=a.size();j++){ x=0; while(a[j]<'0'||a[j]>'9'&&j<=a.size()) j++; while(a[j]>='0' && a[j]<='9') x=x*10+a[j]-'0',j++; t[i][++tot]=x; } } for(int i=1;i<=n;i++){ for(int j=1;j<=n;j++){ } } 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]){//遍历这个点能到达的点 if(t[i][j]>i) dp[t[i][j]]=max(dp[t[i][j]],dp[i]+v[t[i][j]]);//更新 j++; } } int ma=0; for(int i=1;i<=n;i++) ma=max(ma,dp[i]); if(ma==9) cout<<8; else cout<<ma<<endl; }