2019ICPC沈阳网络赛-D-Fish eating fruit(树上DP, 换根, 点分治)
链接:
https://nanti.jisuanke.com/t/41403
题意:
State Z is a underwater kingdom of the Atlantic Ocean. This country is amazing. There are nn cities in the country and n-1n−1 undirected underwater roads which connect all cities.
In order to save energy and avoid traffic congestion, the king promulgated a series of traffic regulations:
Residents have to travel on fish!
Residents need to feed the fish before you start your trip!The amount of food you feed the fish should be exactly the total distance of your journey.
What kind of food to feed depends on the total distance of your journey!Total distance is a multiple of three. You should feed the fish with Durian. Total distance modulus 33 equaling 11. It should be Papaya.Total distance modulus 33 equaling 22. It should be Avocado!!!
Sure, fish like to eat these fruits very much.
Today is the first day of the king's decree. Because the residents here are not good at mathematics, they don't know how much fruit they need to give fish to go to other cities. So the king give an order to the energy minister Ynaonlctrm From all cities to all cities directly, which means that he will make n*(n-1)n∗(n−1) trips.
For example, A - (5 mile) - B - (5 mile) - C, he needs to run the fish, starting at A, passing B, finally arriving C (papaya 10 kg), also he needs to start at C and end at A (papaya 10 kg). Indirect passage is useless. "I've passed City B, my dear emperor." "Oh! It's no use! Not directly! People in cities will never know how much the fish need to eat! The fish will surely die!!! You also need to take several trips which start at B or end with B!" The Emperor said.
It's really a tough task. Can you help him figure out how much fruit he needs to prepare for the emperor's mission?
思路:
题解是树上DP, 比赛时候想到DP,和点分治,但是都没怎么学过, 赛后看题解..还要换根..没听过.
换根就是先DFS一遍之后,根据第一遍DFS得到的结果去处理第二遍DFS,第二遍DFS就是将每个点都看成一个根.
本题令Cnt1[i][j]为以root为根,i的子树中距i的距离%3为j的点的数量.Dp1[i][j]则是i的子树中距i为j的距离路径总和.
这两种状态可以用一遍DFS求得, root就是自己设的根.
第二遍DFS就是处理每个点为根的情况.
考虑Cnt2[i][j], 在以root为根的情况下, 非i的子节点到i的距离%3为j的节点个数.
令v为当前节点, u为其父节点
推出式子
Cnt2[v][(j+len)%3] = Cnt1[u][j]-Cnt1[v][((j-len)%3+3)%3]+Cnt2[u][j].
其中因为u的子节点包括了v的子节点, 需要处理掉.就是减掉.在加上父亲非子节点的贡献.
考虑路径和.同理, 减掉多余的贡献.加上父亲节点的非子节点的贡献.具体看代码.
点分治代码留着补
代码:
#include <bits/stdc++.h>
using namespace std;
typedef long long LL;
const int MOD = 1e9+7;
const int MAXN = 2e4+10;
struct Node
{
int to;
int dis;
};
int Cnt1[MAXN][3], Cnt2[MAXN][3];
LL Dp1[MAXN][3], Dp2[MAXN][3];
LL res[3];
vector<Node> G[MAXN];
int n;
void Dfs1(int u, int v)
{
Cnt1[v][0] = 1;
for (int i = 0;i < G[v].size();i++)
{
int to = G[v][i].to;
int len = G[v][i].dis;
if (to == u)
continue;
Dfs1(v, to);
for (int j = 0;j < 3;j++)
{
Cnt1[v][(j+len)%3] += Cnt1[to][j];
Dp1[v][(j+len)%3] = (Dp1[v][(j+len)%3] + Dp1[to][j] + (len*Cnt1[to][j])%MOD)%MOD;
}
}
}
void Dfs2(int u, int v)
{
// cout << u << ' ' << v << endl;
for (int i = 0;i < G[v].size();i++)
{
int to = G[v][i].to;
int len = G[v][i].dis;
if (to == u)
continue;
for (int j = 0;j < 3;j++)
{
Cnt2[to][(j+len)%3] = Cnt1[v][j] - Cnt1[to][((j-len)%3+3)%3] + Cnt2[v][j];
Dp2[to][(j+len)%3] = ((((Dp1[v][j] - Dp1[to][((j-len)%3+3)%3]) - (len*Cnt1[to][((j-len)%3+3)%3]))%MOD+MOD)%MOD
+ Dp2[v][j] + (len*Cnt2[to][(j+len)%3])%MOD)%MOD;
}
Dfs2(v, to);
}
}
int main()
{
while (~scanf("%d", &n))
{
for (int i = 1;i <= n;i++)
G[i].clear();
memset(Cnt1, 0, sizeof(Cnt1));
memset(Cnt2, 0, sizeof(Cnt2));
memset(Dp1, 0, sizeof(Dp1));
memset(Dp2, 0, sizeof(Dp2));
memset(res, 0, sizeof(res));
int l, r, v;
for (int i = 1;i < n;i++)
{
scanf("%d%d%d", &l, &r, &v);
l++, r++;
G[l].push_back(Node{r, v});
G[r].push_back(Node{l, v});
}
Dfs1(0, 1);
Dfs2(0, 1);
for (int i = 1;i <= n;i++)
{
for (int j = 0;j < 3;j++)
res[j] = (res[j] + Dp1[i][j] + Dp2[i][j])%MOD;
}
printf("%lld %lld %lld\n", res[0], res[1], res[2]);
}
return 0;
}
2019ICPC沈阳网络赛-D-Fish eating fruit(树上DP, 换根, 点分治)的更多相关文章
- 2019icpc沈阳网络赛 D Fish eating fruit 树形dp
题意 分别算一个树中所有简单路径长度模3为0,1,2的距离和乘2. 分析 记录两个数组, \(dp[i][k]\)为距i模3为k的子节点到i的距离和 \(f[i][k]\)为距i模3为k的子节点的个数 ...
- 2019 沈阳网络赛 D Fish eating fruit ( 树形DP)
题目传送门 题意:求一颗树中所有点对(a,b)的路径长度,路径长度按照模3之后的值进行分类,最后分别求每一类的和 分析:树形DP \(dp[i][j]\) 表示以 i 为根的子树中,所有子节点到 i ...
- 2019ICPC沈阳网络赛-B-Dudu's maze(缩点)
链接: https://nanti.jisuanke.com/t/41402 题意: To seek candies for Maomao, Dudu comes to a maze. There a ...
- 2019ICPC上海网络赛 A Lightning Routing I 点分树(动态点分治)+线段树
题意 给一颗带边权的树,有两种操作 \(C~e_i~w_i\),将第\(e_i\)条边的边权改为\(w_i\). \(Q~v_i\),询问距\(v_i\)点最远的点的距离. 分析 官方题解做法:动态维 ...
- Fish eating fruit 沈阳网络赛(树形dp)
Fish eating fruit \[ Time Limit: 1000 ms \quad Memory Limit: 262144 kB \] 题意 大体的题意就是给出一棵树,求每一对点之间的距离 ...
- 2018 ICPC 沈阳网络赛
2018 ICPC 沈阳网络赛 Call of Accepted 题目描述:求一个算式的最大值与最小值. solution 按普通算式计算方法做,只不过要同时记住最大值和最小值而已. Convex H ...
- 线段树+单调栈+前缀和--2019icpc南昌网络赛I
线段树+单调栈+前缀和--2019icpc南昌网络赛I Alice has a magic array. She suggests that the value of a interval is eq ...
- 2019ICPC南京网络赛A题 The beautiful values of the palace(三维偏序)
2019ICPC南京网络赛A题 The beautiful values of the palace https://nanti.jisuanke.com/t/41298 Here is a squa ...
- 沈阳网络赛 F - 上下界网络流
"Oh, There is a bipartite graph.""Make it Fantastic." X wants to check whether a ...
随机推荐
- jvm的学习笔记:二、类的初始化,代码实战(1)
对于静态字段来说,直接定义该字段的类才会被初始化 System.out.println(MyChild1.str); 输出: myParent1 static block hello myParent ...
- 使用URLOS在linux系统中极速部署NFS共享存储服务
如何在linux系统里搭建NFS服务?其实我们只需要安装一个URLOS面板,然后就能在3分钟内将NFS服务部署完成.近日,URLOS在应用市场中上架了一款NFS应用,它可以让我们的节点主机在3分钟内极 ...
- python基础之编码
ascci:字母.数字.特色字符,1个字节-8位Unicode:两个字节-16位,升级版四个字节-32位uft-8:最少一个字节-8位,英文字母-1个字节-8位,欧洲-2个字节-16位,中文-3个字节 ...
- PowerShell学习记录
一.简介——连接 Powershell 是运行在windows机器上实现系统和应用程序管理自动化的命令行脚本环境.你可以把它看成是命令行提示符cmd.exe的扩充,不对,应当是颠覆. powershe ...
- [HDU517] 小奇的集合
题目链接 显然有贪心每次选择最大的两个数来做. 于是暴力地把最大的两个数调整到非负(暴力次数不超过1e5),接下来使用矩阵乘法即可. \[ \begin{pmatrix} B'\\S'\\T' \en ...
- Swoft 2.0.5 更新,新增高效秒级定时任务、异常管理组件
什么是 Swoft ? Swoft 是一款基于 Swoole 扩展实现的 PHP 微服务协程框架.Swoft 能像 Go 一样,内置协程网络服务器及常用的协程客户端且常驻内存,不依赖传统的 PHP-F ...
- React源码深度解析视频 某课网(完整版)
<ignore_js_op> [课程介绍]: React毫无疑问是前端界主流的框架,而框架本身就是热点.课程以讲解React实现原理为主,并在实现过程中讲解这么做的原因,带来 ...
- react 基础语法使用
刚开始不久react,在菜鸟上及其他前辈网站上学习,下面开始我的自学笔记. 包括: 渲染元素 组件(函数方法定义.es6 class定义) 事件处理 条件渲染 列表 下面代码部分将不会再写html部分 ...
- java接口自动化测试小dome
GitHub地址:https://github.com/leonInShanghai/InterfaceAutomation 这个dome 请求 https://www.v2ex.com/api/no ...
- 复选框实现单选效果js/jq
方法一: <input type="checkbox" name="test" onclick="checkedThis(this);" ...