Run ID | 作者 | 问题 | 语言 | 测评结果 | 分数 | 时间 | 内存 | 代码长度 | 提交时间 |
---|---|---|---|---|---|---|---|---|---|
75060 | 这个人没有防范意识 | 金矿 | C++ | 运行超时 | 60 | 773 MS | 292 KB | 660 | 2023-04-18 13:48:09 |
#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]; 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]){//遍历这个点能到达的点 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]); cout<<ma<<endl; }