acgo题库
  • 首页
  • 题库
  • 学习
  • 竞赛
  • 讨论
  • 排行
  • 团队
  • 备赛专区

    竞赛

    • CSP-J/S
    • 蓝桥杯

    考级

    • GESP
    • CPA
    • 电子学会考级
登录
注册
题目详情提交记录(0)
  • 题解,求点赞

    #include<bits/stdc++.h> using namespace std; int n,a[101]; long long ans[101]; vector<int> ve[101]; void dfs(int cur_node,int cur_fa){ ans[cur_node]=a[cur_node]; for(int i=0;i<ve[cur_node].size();i++){ if(ve[cur_node][i]!=cur_fa){ dfs(ve[cur_node][i],cur_node); ans[cur_node]+=max(0LL,ans[ve[cur_node][i]]); } } } int main(){ cin>>n; for(int i=1;i<=n;i++) cin>>a[i]; for(int i=1;i<n;i++){ int u,v; cin>>u>>v; ve[u].push_back(v); ve[v].push_back(u); } dfs(1,0); long long maxn=0; for(int i=1;i<=n;i++) maxn=max(maxn,ans[i]); cout<<maxn; return 0; }

    userId_undefined

    还没想好

    时间刺客模拟·模拟练习生贪心·贪心尝试者分治·分治练习生递归·套娃学徒格式·格式排版员
    3阅读
    0回复
    0点赞
暂无数据

提交答案之后,这里将显示提交结果~

首页