P1351 联合权值

题目描述

无向连通图 \(G\) 有 \(n\) 个点,\(n-1\) 条边。点从 \(1\) 到 \(n\) 依次编号,编号为 \(i\) 的点的权值为 \(W_i\)​,每条边的长度均为 \(1\)。图上两点 \((u, v)\) 的距离定义为 \(u\) 点到 \(v\) 点的最短距离。对于图 \(G\) 上的点对 \((u, v)\),若它们的距离为 \(2\),则它们之间会产生\(W_v \times W_u\)​ 的联合权值。

请问图 \(G\) 上所有可产生联合权值的有序点对中,联合权值最大的是多少?所有联合权值之和是多少?

输入格式

第一行包含 \(1\) 个整数 \(n\)。

接下来 \(n-1\) 行,每行包含 \(2\) 个用空格隔开的正整数 \(u,v\),表示编号为 \(u\) 和编号为 \(v\) 的点之间有边相连。

最后 \(1\) 行,包含 \(n\) 个正整数,每两个正整数之间用一个空格隔开,其中第 \(i\) 个整数表示图 \(G\) 上编号为 \(i\) 的点的权值为 \(W_i\)​。

输出格式

输出共 \(1\) 行,包含 \(2\) 个整数,之间用一个空格隔开,依次为图 \(G\) 上联合权值的最大值和所有联合权值之和。由于所有联合权值之和可能很大,输出它时要对\(10007\)取余。

输入输出样例

输入 #1

5

1 2

2 3

3 4

4 5

1 5 2 3 10

输出 #1

20 74

说明/提示

本例输入的图如上所示,距离为2 的有序点对有\(( 1,3)\) 、\(( 2,4)\) 、\(( 3,1)\) 、\(( 3,5)\)、\(( 4,2)\) 、\(( 5,3)\)。

其联合权值分别为2 、15、2 、20、15、20。其中最大的是20,总和为74。

【数据说明】

对于30%的数据,\(1 < n \leq 100\);

对于60%的数据,\(1 < n \leq 2000\);

对于100%的数据,\(1 < n \leq 200000, 0 < W_i \leq 10000\)。

保证一定存在可产生联合权值的有序点对。

【思路】

树上问题 + dfs

一开始没往树上操作这个地方想就想打个暴力搜索那点部分分

然后发现暴搜是很麻烦的,好像是没法处理类似菊花图的图形

所以只能上树

可以分为两个部分第一个部分先预处理出每一个点对应的长度为1的菊花图里面的最大值和最大值的位置,同时也求出

这个点对应的菊花图里面所有子节点的和

因为后面求总和的时候可以用一个点的值乘以这个菊花图的总和减去那个点的值

然后再来一个dfs

先处理处不是菊花图也就是直上直下不拐弯的那种可能出现的情况也暴力比较找最大值

然后再枚举菊花图,比较里面哪一个除了最大点的点和最大的的乘积最大

也就是找出次大点记录,同时求和,就用上面的方法就可以了

【完整代码】

#include<iostream>
#include<cstdio>
#include<vector> using namespace std;
const int Max = 2e5 + 10;
const int mo = 1e4 + 7;
int a[Max];
int father[Max];
int maxw[Max],maxv[Max];//某个点对应的子节点里面的最大值和最大值的位置
int sum[Max];//某个点对应的子节点之和
vector<int>e[Max];
int n;
int ans1,ans2; void dfs1(int x,int fa)
{
for(int i = 0;i < e[x].size();i ++)
{
if(e[x][i] != fa)
{
if(a[e[x][i]] > maxw[x])
maxw[x] = a[e[x][i]],maxv[x] = e[x][i];
sum[x] = (sum[x] + a[e[x][i]]) % mo;
dfs1(e[x][i],x);
}
}
} void dfs2(int x,int fa)
{
father[x] = fa;
if(father[father[x]] != 0)
{
ans1 = max(ans1,a[father[father[x]]] * a[x]);
ans2 = (ans2 + 2 * a[x] * a[father[father[x]]]) % mo;
}
for(int i = 0;i < e[x].size();i ++)
{
if(e[x][i] != fa)
{
if(e[x][i] != maxv[x])ans1 = max(ans1,a[e[x][i]] * maxw[x]);
ans2 = (ans2 + a[e[x][i]] * (sum[x] - a[e[x][i]])) % mo;
dfs2(e[x][i],x);
}
}
} int main()
{
// freopen("2","r",stdin);
int x,y;
scanf("%d",&n);
// for(int i = 1;i <= n;++ i)
// father[i] = i;
for(int i = 1;i < n;++ i)
{
scanf("%d%d",&x,&y);
e[x].push_back(y);
e[y].push_back(x);
}
for(int i = 1;i <= n;++ i)
scanf("%d",&a[i]);
dfs1(1,0);
dfs2(1,0);
cout<<ans1<<" "<<ans2 % mo<<endl;
return 0;
}

洛谷 P1351 联合权值 题解的更多相关文章

  1. 『题解』洛谷P1351 联合权值

    更好的阅读体验 Portal Portal1: Luogu Portal2: LibreOJ Description 无向连通图\(\mathrm G\)有\(n\)个点,\(n - 1\)条边.点从 ...

  2. [NOIP2014] 提高组 洛谷P1351 联合权值

    题目描述 无向连通图G 有n 个点,n - 1 条边.点从1 到n 依次编号,编号为 i 的点的权值为W i ,每条边的长度均为1 .图上两点( u , v ) 的距离定义为u 点到v 点的最短距离. ...

  3. 洛谷 P1351 联合权值

    题目描述 无向连通图G 有n 个点,n - 1 条边.点从1 到n 依次编号,编号为 i 的点的权值为W i ,每条边的长度均为1 .图上两点( u , v ) 的距离定义为u 点到v 点的最短距离. ...

  4. 洛谷——P1351 联合权值

    https://www.luogu.org/problem/show?pid=1351 题目描述 无向连通图G 有n 个点,n - 1 条边.点从1 到n 依次编号,编号为 i 的点的权值为W i , ...

  5. 洛谷P1351 联合权值(树形dp)

    题意 题目链接 Sol 一道很简单的树形dp,然而被我写的这么长 分别记录下距离为\(1/2\)的点数,权值和,最大值.以及相邻儿子之间的贡献. 树形dp一波.. #include<bits/s ...

  6. 洛谷 P1351 联合权值 —— 树形DP

    题目:https://www.luogu.org/problemnew/show/P1351 树形DP,别忘了子树之间的情况(拐一下距离为2). 代码如下: #include<iostream& ...

  7. 洛谷P1351 联合权值

    \(\Large\textbf{Description:}\) \(\large一棵树,父子之间距离为1,求距离为2的两点点权之积的最大值与和.\) \(\Large\textbf{Solution: ...

  8. Luogu P1351 联合权值 题解

    这是一个不错的树形结构的题,由于本蒟蒻不会推什么神奇的公式其实是懒得推...,所以很愉快的发现其实只需要两个点之间的关系为祖父和儿子.或者是兄弟即可. 然后问题就变得很简单了,只需要做一个正常的DFS ...

  9. 洛谷 1351 联合权值——树形dp

    题目:https://www.luogu.org/problemnew/show/P1351 对拍了一下,才发现自己漏掉了那种拐弯的情况. #include<iostream> #incl ...

随机推荐

  1. ELK学习笔记之配置logstash消费kafka多个topic并分别生成索引

    0x00 filebeat配置多个topic filebeat.prospectors: - input_type: log encoding: GB2312 # fields_under_root: ...

  2. FastJson前置属性过滤器

    FastJson前置属性过滤器 /** * <html> * <body> * <P> Copyright 1994 JsonInternational</p ...

  3. 你也可以写个聊天程序 - C# Socket学习1

    原文:你也可以写个聊天程序 - C# Socket学习1 简述 我们做软件工作的虽然每天都离不开网络,可网络协议细节却不是每个人都会接触和深入了解.我今天就来和大家一起学习下Socket,并写一个简单 ...

  4. P1347 排序 (拓扑排序,tarjan)

    题目 P1347 排序 解析 打开一看拓扑排序,要判环. 三种情况 有环(存在矛盾) 没环但在拓扑排序时存在有两个及以上的点入度为0(关系无法确定) 除了上两种情况(关系可确定) 本来懒了一下,直接在 ...

  5. centos7安装face_recognition踩各种坑

    要在阿里云服务器上部署face_recognition.用的是centos7.  千辛万苦啊.感谢网上的各种解答.回报社会,我也把各种坑写下了.整理的有点乱.不过仔细看,有干货的. 感谢这个博主Fat ...

  6. JBOOT使用总结

    @Override public SwAdmin findById(long id) { return DAO.findFirst("SELECT * FROM sw_admin WHERE ...

  7. FFmpeg--如何同步音视频的解决方案

    如何同步视频 PTS和DTS 幸运的是,音频和视频流都有一些关于以多快速度和什么时间来播放它们的信息在里面.音频流有采样,视频流有每秒的帧率.然而,如果我们只是简单的通过数帧和乘以帧率的方式来同步视频 ...

  8. .net 获取CPU频率 内存 磁盘大小,域名 端口 虚拟目录等

    CPU个数: @Environment.GetEnvironmentVariable("NUMBER_OF_PROCESSORS") CPU类型: @Environment.Get ...

  9. day 20 作业

    作业 1.下面这段代码的输出结果将是什么?请解释. class Parent(object): x = 1 class Child1(Parent): pass class Child2(Parent ...

  10. 图记 2016.1.7 获取本地图片、Bitmap转image

    这几天完成的内容有: 1.“添加图片”按钮 2.添加图片功能 遇到的问题: 我想要将添加图片按钮放在右下角,所以采用了相对布局,但是问题随之二来,因为将导航栏设置成了半透明,所以图片放到右下角之后,半 ...