蓝桥杯第131题——生命之树

题目描述

在 X 森林里,上帝创建了生命之树。

他给每棵树的每个节点(叶子也称为一个节点)上,都标了一个整数,代表这个点的和谐值。

上帝要在这棵树内选出一个非空节点集 S,使得对于 S 中的任意两个点 a,b,都存在一个点列 a,v1​,v2​,⋯,vk​,b 使得这个点列中的每个点都是 S 里面的元素,且序列中相邻两个点间有一条边相连。

在这个前提下,上帝要使得 S 中的点所对应的整数的和尽量大。

这个最大的和就是上帝给生命之树的评分。

经过 atm 的努力,他已经知道了上帝给每棵树上每个节点上的整数。但是由于 atm 不擅长计算,他不知道怎样有效的求评分。他需要你为他写一个程序来计算一棵树的分数。

输入描述

第一行一个整数 n 表示这棵树有 n 个节点。

第二行 n 个整数,依次表示每个节点的评分。

接下来 n−1 行,每行 2 个整数 u,v,表示存在一条 u 到 v 的边。由于这是一棵树,所以是不存在环的。

其中,0 < n ≤ 10^5, 每个节点的评分的绝对值不超过 10^6。

输出描述

输出一行一个数,表示上帝给这棵树的分数。

输入输出样例

示例

输入

5
1 -2 -3 4 5
4 2
3 1
1 2
2 5

输出

8

 解题思路

题目说对于集合S中任意的两个点,都存在一条能连起来的路径,指的是S中所有的点都能在其中加上S中别的点连起来,其实就是寻找一颗权值最大的子树,千万注意是树不是一条权值最大的路径

这是一道经典的树形dp,树形dp是结合dfs与递推计算的解题手法,用于在树和图的结构中进行递推计算,该题就是一个经典的应用场景。

我们定义dp[i]表示以节点 i 为根的树(考虑所有儿子,不考虑其父亲)能达到的最高权值;如果与节点 i 相连的节点的dp值是正值,则可以将其加入到该点的dp值中。

import java.util.*;public class Main {static int n;static long[] dp;static int[] w;static ArrayList<ArrayList<Integer>> tree;static long ans = 0;public static void main(String[] args) {Scanner sc = new Scanner(System.in);n = sc.nextInt();w = new int[n + 1];dp = new long[n + 1];tree = new ArrayList<>();tree.add(new ArrayList<>());for (int i = 1; i <= n; i++) {w[i] = sc.nextInt();dp[i] = w[i];tree.add(new ArrayList<>());}for (int i = 0; i < n - 1; i++) {int a = sc.nextInt();int b = sc.nextInt();tree.get(a).add(b);tree.get(b).add(a);}visited = new boolean[n + 1];dfs(1);System.out.println(ans);}public static boolean[] visited;public static void dfs(int root) {visited[root] = true;for (int son : tree.get(root)) {if (!visited[son]) {dfs(son);if (dp[son] > 0) {dp[root] += dp[son];}}}ans = Math.max(ans, dp[root]);visited[root] = false;}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/784638.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C# 字节数组 byte[] 关于byte的小寄巧

怎么读字节数组里面的内容 先是小错误 之 ToString然后是怎么办使用UTF-8编码使用ASCII编码使用其他编码未知编码注意 小demo下一个demo关于发送端的&#xff08;发送新行&#xff09;手搓bug编码之搓ascii encodeing评价为不如BitConverter一根 先是小错误 之 ToString 在C#中…

Linux C++ 011-引用

Linux C 011-引用 本节关键字&#xff1a;Linux、C、引用 相关库函数&#xff1a; 基本的使用 作用&#xff1a;给变量起别名 语法&#xff1a;数据类型& 别名 原名; int a 10;int& b a;b 100; // 此时 a 100注意事项 引用必须初始化 引用在初始化后&#xf…

【网站项目】面向社区健康服务的医疗平台

&#x1f64a;作者简介&#xff1a;拥有多年开发工作经验&#xff0c;分享技术代码帮助学生学习&#xff0c;独立完成自己的项目或者毕业设计。 代码可以私聊博主获取。&#x1f339;赠送计算机毕业设计600个选题excel文件&#xff0c;帮助大学选题。赠送开题报告模板&#xff…

【MATLAB源码-第25期】基于matlab的8QAM调制解调仿真,手动实现未调用内置函数,星座图展示。

操作环境&#xff1a; MATLAB 2022a 1、算法描述 8QAM调制&#xff08;8 Quadrature Amplitude Modulation&#xff09;是一种数字调制技术&#xff0c;它可以在有限带宽内传输更多的信息比特。在8QAM调制中&#xff0c;每个符号可以携带3个比特的信息。QAM调制是将数字信号…

插入排序---算法

1、算法概念 插入排序&#xff1a;它的工作原理是通过构建有序排序&#xff0c;对于未排序数据&#xff0c;在已排序序列中从后向前扫描&#xff0c;找到相应位置插入。 2、算法步骤 将第一待排序序列第一个元素看作一个有序序列&#xff0c;把第二个元素到最后一个元素当成是…

程序员开启网络创作之旅,分享一些真知灼见

我的口袋可能没那些高手那么鼓&#xff0c;不过呢&#xff0c;我更愿意站在一个副业新手的立场上&#xff0c;跟那些跟我差不多的伙计们分享点心得。咱们不指望一夜暴富&#xff0c;只希望能有个稳稳的小收入就心满意足了。 你看&#xff0c;那些在公众号上写出爆文的人&#…

内容营销新手指南:Kompas.ai的智能起步策略

内容营销是当今企业获取客户、建立品牌认知和忠诚度的关键手段。然而&#xff0c;对于刚刚踏入这一领域的新手来说&#xff0c;内容营销的世界可能会显得既广阔又复杂。从内容创作到发布&#xff0c;再到分析和优化&#xff0c;每一步都充满了挑战。本文旨在为内容营销新手提供…

分布式机房运维管理解决方案

一、引言 随着信息技术的快速发展和普及&#xff0c;各行各业对信息系统的依赖程度日益加深。信息系统的稳定运行和高效管理已成为确保业务连续性和降低运营成本的关键。本文旨在探讨一种全面的运维管理解决方案&#xff0c;以实现对分布式机房运行环境的有效监控和管理&#x…

selenium3 自动化测试入门 ~~~ 操作浏览器

前言 该教程适用于selenium 3版本&#xff0c;如果已经更新到selenium 4&#xff0c;启动浏览器的方法需要修改&#xff0c;具体可参考&#xff1a;selenium 4 启动浏览器 前置条件&#xff08;浏览器驱动放置位置&#xff09; 一、第一种方法 1.下载浏览器驱动 2.粘贴在pyt…

数据资产如何入表?有哪些步骤?

当下&#xff0c;数据资产入表这一关键环节对于企业的高效运营与决策制定具有至关重要的作用。软信天成团队经过长期研究与实践&#xff0c;将数据资产入表的全流程归纳总结为四个核心步骤&#xff0c;以期为诸位提供帮忙。 &#xff08;一&#xff09;确保数据合规&#xff0…

jvm(HotSpotVM)学习记录

1&#xff1a;当我们写的java文件经过编译器编译后生成class文件。class文件里面包含了各种java语言规范的特定语法。可以通过javap -v -private xxx.class 例如&#xff1a; javap -v -private Gas.class Classfile /D:/project/ike-springboot-carbonzero-v2/springboot-bms…

前端三剑客 —— CSS (第二节)

目录 内容回顾&#xff1a; CSS选择器*** 属性选择器 伪类选择器 1&#xff09;:link 超链接点击之前 2&#xff09;:visited 超链接点击之后 3&#xff09;:hover 鼠标悬停在某个标签上时 4&#xff09;:active 鼠标点击某个标签时&#xff0c;但没有松开 5&#xff09;:fo…

LabVIEW动车组谐波分析与检测系统

LabVIEW动车组谐波分析与检测系统 随着中国高速铁路网络的快速发展&#xff0c;动车组数量和运行速度的不断提升&#xff0c;其产生的谐波问题对电网产生了不小的影响。基于图形化编程语言LabVIEW&#xff0c;开发了一套动车组谐波分析与检测系统&#xff0c;旨在实时监控与分…

机器视觉/将HIK海康面阵相机连接Halcon软件

文章目录 概述工业相机客户端动态库拷贝Halcon连接HIK相机的配置相机参数其他 概述 本文简述了如何将海康面阵相机连接到Halcon软件中进行实时取图的过程。 补充&#xff0c; 整个实践过程使用 17.12 / x64-win64 Halcon 软件版本 海康 MV-CE200-10GM 面阵相机。从左到右简解…

B树、B+树、哈夫曼树

目录 1. B树2. B树3. 哈夫曼树 1. B树 特点&#xff1a;一个节点当中可以有多个值&#xff0c;节点内部key 值是有序的&#xff0c;节点内部存储的是key-value类型的数据 磁盘中文件存储用B树。 4阶B树一个节点最多三个key值 5阶B树一个节点最多四个key值 B树有很多的分支&…

华为OD机试 - 绘图机器 - 双指针(Java 2024 C卷 100分)

华为OD机试 2024C卷题库疯狂收录中&#xff0c;刷题点这里 专栏导读 本专栏收录于《华为OD机试&#xff08;JAVA&#xff09;真题&#xff08;A卷B卷C卷&#xff09;》。 刷的越多&#xff0c;抽中的概率越大&#xff0c;每一题都有详细的答题思路、详细的代码注释、样例测试…

Matlab中的脚本和函数

Matlab中的脚本和函数 文章目录 Matlab中的脚本和函数脚本创建脚本代码注释函数创建函数局部函数嵌套函数私有函数匿名函数补充知识函数句柄测试环境:Win11 + Matlab R2021a 脚本 ​ Matlab脚本是最简单的程序文件类型。它们可用于自动执行一系列 Matlab 命令,如命令行重复执…

复制初始化

#include <iostream> using namespace std;class Base { public:Base(const char* s) { str s; cout << "Base" << endl;}Base(const Base&) delete; private:const char* str; };int main() {Base d "123"; }上述代码直接将字符…

ROS2 学习(一)ROS2 简介与基本使用

参考引用 动手学 ROS2 1. ROS2 介绍与安装 1.1 ROS2 的历史 ROS&#xff08;Robot Operating System&#xff0c;机器人操作系统&#xff09;&#xff0c;但 ROS 本身并不是一个操作系统&#xff0c;而是可以安装在现在已有的操作系统上&#xff08;Linux、Windows、Mac&…

『VUE』07. v-for 的规范性:通过key管理状态 就地更新渲染策略(详细图文注释)

目录 vue渲染的就地更新策略一个例子说明key的必要性示例代码总结 欢迎关注 『VUE』 专栏&#xff0c;持续更新中 欢迎关注 『VUE』 专栏&#xff0c;持续更新中 如果你遇到了你的页面元素莫名其妙的呈现顺序,可能是你没有设置key. vue渲染的就地更新策略 在 Vue 中&#xff…