当前位置: 首页 > news >正文

旅游网站的市场需求怎么做介绍电子商务网站建设的步骤

旅游网站的市场需求怎么做介绍,电子商务网站建设的步骤,网站怎么做成小程序,抽奖怎么做网站题目链接 [蓝桥杯 2015 省 B] 生命之树 题目描述 在 X 森林里,上帝创建了生命之树。 他给每棵树的每个节点(叶子也称为一个节点)上,都标了一个整数,代表这个点的和谐值。 上帝要在这棵树内选出一个节点集合 S S S&…

题目链接

[蓝桥杯 2015 省 B] 生命之树

题目描述

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

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

上帝要在这棵树内选出一个节点集合 S S S(允许为空集),使得对于 S S S 中的任意两个点 a , b a,b a,b,都存在一个点列 a , v 1 , v 2 , . . . , b a,v_1,v_2,...,b a,v1,v2,...,b , 使得这个点列中的每个点都是 S S S 里面的元素,且序列中相邻两个点间有一条边相连。

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

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

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

输入格式

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

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

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

输出格式

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

输入输出样例
输入
5
1 -2 -3 4 5
4 2
3 1
1 2
2 5
输出
8
数据范围
  • 0 ≤ n ≤ 1 0 5 0 \leq n \leq 10^5 0n105,每个节点的评分不超过 1 0 6 10^6 106

解法:树形dp

按照题目的意思,我们实际就是要求子树的最大点权和

我们定义 f ( i ) f(i) f(i) 表示以节点 i i i 为根节点的最大点权和。按照定义,我们最终返回的值为 m a x { f ( i ) } ( 1 ≤ i ≤ n ) max \{f(i) \} \ (1 \leq i \leq n) max{f(i)} (1in)

j j j i i i 的子节点, f ( i ) = s c o r e [ i ] + ∑ j m a x { 0 , f ( j ) } f(i) = score[i] + \sum_{j}max\{ 0, f(j)\} f(i)=score[i]+jmax{0,f(j)}

由于 S S S 可能是空集,也就是我们可能一个节点也不选,那说明 0 0 0 也是答案之一。

最终答案为 m a x { 0 , f ( i ) } ( 1 ≤ i ≤ n ) max \{ 0, f(i)\} \ (1 \leq i \leq n) max{0,f(i)} (1in)

时间复杂度: O ( n ) O(n) O(n)

C++代码:

#include <iostream>
#include <cstring>
#include <vector>
#include <functional>using namespace std;
using LL = long long;void solve(){int n;cin>>n;vector<int> score(n + 1);for(int i = 1;i <= n;i++) cin>>score[i];vector<vector<int>> g(n + 1);for(int i = 0;i < n - 1;i++){int a, b;cin>>a>>b;g[a].push_back(b);g[b].push_back(a);}vector<LL> f(n + 1);function<void(int, int)> dfs = [&](int u, int fa){f[u] = score[u];for(auto v:g[u]){if(v == fa) continue;dfs(v, u);f[u] += max(0LL, f[v]);}};dfs(1, -1);LL ans = 0;for(int i = 1;i <= n;i++) ans = max(ans, f[i]);cout<<ans<<'\n';}int main(){int t = 1;while(t--){solve();}return 0;
}
http://www.khdw.cn/news/40620.html

相关文章:

  • 书城网站开发的参考文献上海专业优化排名工具
  • 零基础可以做网站吗应用商店优化
  • 哪些网站可以做视频收费最近新闻摘抄
  • 医院网站做品牌推广需要哪些百度网盘客服在线咨询
  • 三合一网站开发成品短视频app源码的优点
  • 鄂州市政府网站建设分析西安seo工作室
  • 做党建需要关注网站sem广告投放是做什么的
  • 廊坊网站建网络服务提供者不是网络运营者
  • 政府大型网站建设网络推广教程
  • 做推广可以在哪些网站发布软文怎么样引流加微信
  • 毕业设计网站开发题目网站seo设计
  • 网站开发行业黄页
  • 多开商城西安的网络优化公司
  • o2o网站建设多少钱中国最厉害的营销策划公司
  • 企业年金办法搜索引擎优化的主要工作
  • 做体力活的网站公司怎么做网络营销
  • 网站静态页面做网站上海网站关键词排名
  • 苏州网站建设系统哪家好seo培训赚钱
  • 贵州网站建设seo优化南京网络推广公司排名
  • 如何开设一个网站seo优化及推广如何运营
  • 一般网站的流量是多少谈谈对seo的理解
  • wordpress退出维护模式seo查询是什么
  • 办公室装修一般多少钱一个平方站群优化公司
  • 做网站和做微信小程序semantic
  • 上海企业建站工具网络营销岗位职责和任职要求
  • 课程网站建设的设计报告seo服务如何收费
  • 大网站整站备份百度电脑端网页版入口
  • 南通网站建设.百度app下载安装
  • 武汉做网站哪里便宜求个网站
  • 成都做网站的公司哪家好google海外版