2019长安大学ACM校赛网络同步赛C LaTale (树上DP)
链接:https://ac.nowcoder.com/acm/contest/897/C
来源:牛客网
空间限制:C/C++ 32768K,其他语言65536K
64bit IO Format: %lld
题目描述
Define d(u, v) the length between city u and city v. Under the condition of u differing from v, please answer how many pairs(u, v) in which d(u, v) can be divisible by 3.
     Pair(u,v) and pair(v,u) are considered the same.
输入描述:
The first line contains an integer number T, the number of test cases.
The following n-1 lines, each contains three integers uiui, vivi, wiwi(1≤ui,vi≤n,1≤wi≤10001≤ui,vi≤n,1≤wi≤1000), the edge of cities.
输出描述:
For each test case print the number of pairs required.
输出
2
6 题意:
给你一个含有n个节点的树,
问有多少对节点u,v,他们的距离dist(u,v)%3==0 思路:
树上dp
我们定义状态 dp[i][0/1/2]
表示第i个节点的子树中,距离第i个节点的距离%3的分别等于0、1、2三种情况的节点个数。
然后根据节点之间的关系转移。
对于一堆节点u,v。对答案的贡献是:
dp[u][j]*dp[v][(3-w-j+3)%3];
j 分别取0 1 2
然后再把底层的节点信息转移给它的父节点即可、 细节见代码:
#include <iostream>
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <cmath>
#include <queue>
#include <stack>
#include <map>
#include <set>
#include <vector>
#include <iomanip>
#define ALL(x) (x).begin(), (x).end()
#define rt return
#define dll(x) scanf("%I64d",&x)
#define xll(x) printf("%I64d\n",x)
#define sz(a) int(a.size())
#define all(a) a.begin(), a.end()
#define rep(i,x,n) for(int i=x;i<n;i++)
#define repd(i,x,n) for(int i=x;i<=n;i++)
#define pii pair<int,int>
#define pll pair<long long ,long long>
#define gbtb ios::sync_with_stdio(false),cin.tie(0),cout.tie(0)
#define MS0(X) memset((X), 0, sizeof((X)))
#define MSC0(X) memset((X), '\0', sizeof((X)))
#define pb push_back
#define mp make_pair
#define fi first
#define se second
#define eps 1e-6
#define gg(x) getInt(&x)
#define db(x) cout<<"== [ "<<x<<" ] =="<<endl;
using namespace std;
typedef long long ll;
ll gcd(ll a, ll b) {return b ? gcd(b, a % b) : a;}
ll lcm(ll a, ll b) {return a / gcd(a, b) * b;}
ll powmod(ll a, ll b, ll MOD) {ll ans = ; while (b) {if (b % )ans = ans * a % MOD; a = a * a % MOD; b /= ;} return ans;}
inline void getInt(int* p);
const int maxn = ;
const int inf = 0x3f3f3f3f;
/*** TEMPLATE CODE * * STARTS HERE ***/
struct edge
{
int next;
int to;
int dis;
edge()
{ }
edge(int nn, int dd)
{
next = nn;
dis = dd;
}
};
edge e[maxn << ];
ll ans = 0ll;
int tot;
int head[maxn << ];
void addedge(int a, int b, int c)
{
e[tot].to = b;
e[tot].dis = c;
e[tot].next = head[a];
head[a] = tot++;
}
void init()
{
tot = ;
}
ll dp[maxn][]; void dfs(int id, int pre)
{
dp[id][] = 1ll;
for (int i = head[id]; i != ; i = e[i].next)
{
edge x = e[i];
ll w = x.dis;
if (x.to != pre)
{
dfs(x.to, id);
ans += dp[id][] * dp[x.to][( - w - + ) % ];
ans += dp[id][] * dp[x.to][( - w - + ) % ];
ans += dp[id][] * dp[x.to][( - w - + ) % ];
dp[id][( + w) % ] += dp[x.to][];
dp[id][( + w) % ] += dp[x.to][];
dp[id][( + w) % ] += dp[x.to][]; }
} }
int main()
{
//freopen("D:\\common_text\\code_stream\\in.txt","r",stdin);
//freopen("D:\\common_text\\code_stream\\out.txt","w",stdout); int t;
gbtb;
cin >> t;
while (t--)
{
ans = 0ll;
int n;
cin >> n;
init();
int a, b, c;
repd(i, , n)
{
head[i] = ;
dp[i][] = dp[i][] = dp[i][] = ;
}
repd(i, , n)
{
cin >> a >> b >> c;
c %= ;
addedge(a, b, c);
addedge(b, a, c);
}
dfs(, );
cout << ans << endl;
} return ;
} inline void getInt(int* p) {
char ch;
do {
ch = getchar();
} while (ch == ' ' || ch == '\n');
if (ch == '-') {
*p = -(getchar() - '');
while ((ch = getchar()) >= '' && ch <= '') {
*p = *p * - ch + '';
}
}
else {
*p = ch - '';
while ((ch = getchar()) >= '' && ch <= '') {
*p = *p * + ch - '';
}
}
}
2019长安大学ACM校赛网络同步赛C LaTale (树上DP)的更多相关文章
- 2019长安大学ACM校赛网络同步赛 L	XOR (规律,数位DP)
		
链接:https://ac.nowcoder.com/acm/contest/897/L 来源:牛客网 XOR 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 32768K,其他语言6 ...
 - 2019长安大学ACM校赛网络同步赛  J	Binary Number(组合数学+贪心)
		
链接:https://ac.nowcoder.com/acm/contest/897/J 来源:牛客网 Binary Number 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 32 ...
 - 2019长安大学ACM校赛网络同步赛 B	Trial of Devil (递归)
		
链接:https://ac.nowcoder.com/acm/contest/897/B来源:牛客网 Trial of Devil 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 32 ...
 - 2019长安大学ACM校赛网络同步赛 M	LCM (数论)
		
链接:https://ac.nowcoder.com/acm/contest/897/M来源:牛客网 LCM 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 32768K,其他语言65 ...
 - 南昌大学航天杯第二届程序设计竞赛校赛网络同步赛 I
		
链接:https://www.nowcoder.com/acm/contest/122/I来源:牛客网 题目描述 小q最近在做一个项目,其中涉及到了一个计时器的使用,但是笨笨的小q却犯难了,他想请你帮 ...
 - NOI 2018网络同步赛(游记?)
		
刚中考完那段时间比较无聊,报名了一个同步赛,报完名才发现成绩单是要挂到网上的,而且因为报的早给了一个很靠前的考号...那布星啊,赶紧学点东西,于是在一周内学了网络流,Treap以及一些数论. Day1 ...
 - 第十三届北航程序设计竞赛决赛网络同步赛 B题 校赛签到(建树 + 打标记)
		
题目链接 校赛签到 对每个操作之间建立关系. 比较正常的是前$3$种操作,若第$i$个操作属于前$3$种,那么就从操作$i-1$向$i$连一条有向边. 比较特殊的是第$4$种操作,若第$i$个操作属 ...
 - 哈尔滨理工大学ACM全国邀请赛(网络同步赛)题解
		
题目链接 提交连接:http://acm-software.hrbust.edu.cn/problemset.php?page=5 1470-1482 只做出来四道比较水的题目,还需要加强中等题的训练 ...
 - $NOI$ $2019$ 网络同步赛
		
D2T1考试前测了自己造的“假”极限数据,看了看内存发现是118MB,感觉没问题就交上去了. 赛后用Lemon测了一下:MLE 88->0 对于别的题我已经不想再说什么了. update: 由于 ...
 
随机推荐
- [ros] ros入门记录
			
ROS入门 半天入门ROS,总体感觉比较好理解,python写不用编译超级爽,学完ros去学电控去了. ros2比ros1好用,所以最终是学ros2. ros1 安装 添加源 > sudo sh ...
 - zay大爷的膜你题 D2T2——不老梦(AK梦)
			
还是万年不变的外链 这个题.....是最难的....但是不知道为啥扶苏神仙讲完了之后我竟然听懂了.... 所以这个题我要好好写一写 首先我们看一看每一个测试点,来一点点得分 第一个测试点n = 1,直 ...
 - WPF中的WndProc
			
其实,在WPF中,要想利用WndProc来处理所有的事件,需要利用到SourceInitialized Event,首先需要创建一个HwndSource对象,然后利用其AddHook方法来将所有的w ...
 - jQuery验证控件jquery.validate.js汉化
			
如需要修改,可在js代码中加入: jQuery.extend(jQuery.validator.messages, { required: "必选字段", remote: &q ...
 - 【MM系列】SAP MM物料账在制品承担差异功能及配置
			
公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文链接:[MM系列]SAP MM物料账在制品承担差异功能 ...
 - 【css】子元素浮动到了父元素外,父元素没有随子元素自适应高度,如何解决?
			
正常情况 如果子元素没有设置浮动(float),父元素的高度会随着子元素高度的改变而改变的. 设置浮动以后 父元素的高度不会随着子元素的高度而变化. 例如:在一个ul中定义若干个li,并设置float ...
 - javascript 异常处理
			
<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8" ...
 - C语言Ⅰ博客作业02
			
1. 这个作业属于哪个课程 C语言程序设计Ⅰ 这个作业要求在哪里 https://edu.cnblogs.com/campus/zswxy/CST2019-3/homework/8656 我在这个课程 ...
 - [Web 前端] 031 bootstrap 的使用和全局 css 样式
			
目录 0. 前言 1. 基本模板 2. 布局容器 2.1 container 2.2 container-fluid 3. 栅格系统 3.1 简介 3.2 栅格参数 3.3 实例:从堆叠到水平排列 2 ...
 - SpringMVC框架  课程笔记
			
SpringMVC框架 课程笔记 第0章 SpringMVC框架的核心内容 1.SpringMVC 概述 2.SpringMVC 的 HelloWorld 3.使用 @RequestMapping 映 ...