热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

【牛客每日一题】4.15Treepath题解(树上dfs/树形DP)

题目链接:https:ac.nowcoder.comacmproblem14248来源:牛客网题目描述给定一棵n个点的树,问其中有多少

题目链接:https://ac.nowcoder.com/acm/problem/14248
来源:牛客网

题目描述

给定一棵n个点的树,问其中有多少条长度为偶数的路径。路径的长度为经过的边的条数。x到y与y到x被视为同一条路径。路径的起点与终点不能相同。
输入描述:
第一行一个数n表示点的个数&#xff1b;接下来n-1行&#xff0c;每行两个整数x&#xff0c;y表示边&#xff1b;保证输入数据形成一棵树&#xff1b;1<&#61;n<&#61;100000
输出描述:
一行一个整数表示答案。

示例1

输入

3
1 2
1 3

输出

1

题目要求长度为偶数的路径数&#xff0c;那么先用链式前向星建图&#xff0c;然后从深度角度出发, 以 1 为根 dfs 求出全部深度

那么我们画个图观察一下&#xff0c;发现偶数层到偶数层 距离为偶数
奇数到奇数层 距离距离也为偶数
那么我们求出奇数层节点为a, 偶数层节点个数为b
答案为排列组合&#xff0c;C(a,2)&#43;C(b,2)C(a,2)&#43;C(b,2)C(a,2)&#43;C(b,2)
换成代码就是(a−1)∗a/2&#43;(b−1)∗b/2(a - 1) * a / 2 &#43; (b - 1) *b / 2(a1)a/2&#43;(b1)b/2
时间复杂度
O(n)O(n)O(n)
在这里插入图片描述

#include
#define ls (p<<1)
#define rs (p<<1|1)
#define mid (l&#43;r)/2
#define over(i,s,t) for(register long long i&#61;s;i<&#61;t;&#43;&#43;i)
#define lver(i,t,s) for(register long long i&#61;t;i>&#61;s;--i)
//#define int __int128
using namespace std;
typedef long long ll;//全用ll可能会MLE或者直接WA,试着改成int看会不会A
const ll N&#61;100007;
const ll INF&#61;1e10&#43;9;
const double EPS&#61;1e-10;//-10次方约等于趋近为0
ll dep[N];
ll n,head[N],tot;
struct node
{ll v,nex;
}G[N<<1];
void add(ll u,ll v)
{G[&#43;&#43;tot].v&#61;v;G[tot].nex&#61;head[u];head[u]&#61;tot;
}void dfs(ll u,ll fa)
{dep[u]&#61;dep[fa]&#43;1;for(ll i&#61;head[u];i;i&#61;G[i].nex){if(G[i].v&#61;&#61;fa)continue;dfs(G[i].v,u);}
}
int main()
{scanf("%lld",&n);over(i,1,n-1){ll x,y;scanf("%lld%lld",&x,&y);add(x,y);add(y,x);}dfs(1,0);ll a&#61;0,b&#61;0;over(i,1,n)if(dep[i]&1)a&#43;&#43;;else b&#43;&#43;;printf("%lld\n",ll(a*(a-1)/2)&#43;ll(b*(b-1)/2));return 0;
}

还有一种树形DP我明天再写&#xff0c;先睡了

附上官方题解&#xff1a;
【每日一题】4月15日题目精讲
在这里插入图片描述


推荐阅读
  • Codeforces Round #566 (Div. 2) A~F个人题解
    Dashboard-CodeforcesRound#566(Div.2)-CodeforcesA.FillingShapes题意:给你一个的表格,你 ... [详细]
  • 火星商店问题:线段树分治与持久化Trie树的应用
    本题涉及编号为1至n的火星商店,每个商店有一个永久商品价值v。操作包括每天在指定商店增加一个新商品,以及查询某段时间内某些商店中所有商品(含永久商品)与给定密码值的最大异或结果。通过线段树分治和持久化Trie树来高效解决此问题。 ... [详细]
  • 深入理解Redis的数据结构与对象系统
    本文详细探讨了Redis中的数据结构和对象系统的实现,包括字符串、列表、集合、哈希表和有序集合等五种核心对象类型,以及它们所使用的底层数据结构。通过分析源码和相关文献,帮助读者更好地理解Redis的设计原理。 ... [详细]
  • 本文探讨了如何在模运算下高效计算组合数C(n, m),并详细介绍了乘法逆元的应用。通过扩展欧几里得算法求解乘法逆元,从而实现除法取余的计算。 ... [详细]
  • 题目Link题目学习link1题目学习link2题目学习link3%%%受益匪浅!-----&# ... [详细]
  • 本题涉及一棵由N个节点组成的树(共有N-1条边),初始时所有节点均为白色。题目要求处理两种操作:一是改变某个节点的颜色(从白变黑或从黑变白);二是查询从根节点到指定节点路径上的第一个黑色节点,若无则输出-1。 ... [详细]
  • 编程挑战:2019 Nitacm 校赛 D 题 - 雷顿女士与分队(高级版)
    本文深入解析了2019年Nitacm校赛D题——雷顿女士与分队(高级版),详细介绍了问题背景、解题思路及优化方案。 ... [详细]
  • 本文探讨了如何通过最小生成树(MST)来计算严格次小生成树。在处理过程中,需特别注意所有边权重相等的情况,以避免错误。我们首先构建最小生成树,然后枚举每条非树边,检查其是否能形成更优的次小生成树。 ... [详细]
  • Explore how Matterverse is redefining the metaverse experience, creating immersive and meaningful virtual environments that foster genuine connections and economic opportunities. ... [详细]
  • 本文探讨了如何在给定整数N的情况下,找到两个不同的整数a和b,使得它们的和最大,并且满足特定的数学条件。 ... [详细]
  • Splay Tree 区间操作优化
    本文详细介绍了使用Splay Tree进行区间操作的实现方法,包括插入、删除、修改、翻转和求和等操作。通过这些操作,可以高效地处理动态序列问题,并且代码实现具有一定的挑战性,有助于编程能力的提升。 ... [详细]
  • 本实验主要探讨了二叉排序树(BST)的基本操作,包括创建、查找和删除节点。通过具体实例和代码实现,详细介绍了如何使用递归和非递归方法进行关键字查找,并展示了删除特定节点后的树结构变化。 ... [详细]
  • MySQL索引详解与优化
    本文深入探讨了MySQL中的索引机制,包括索引的基本概念、优势与劣势、分类及其实现原理,并详细介绍了索引的使用场景和优化技巧。通过具体示例,帮助读者更好地理解和应用索引以提升数据库性能。 ... [详细]
  • 本文将详细探讨Linux pinctrl子系统的各个关键数据结构,帮助读者深入了解其内部机制。通过分析这些数据结构及其相互关系,我们将进一步理解pinctrl子系统的工作原理和设计思路。 ... [详细]
  • 本文详细介绍了如何在Linux系统上安装和配置Smokeping,以实现对网络链路质量的实时监控。通过详细的步骤和必要的依赖包安装,确保用户能够顺利完成部署并优化其网络性能监控。 ... [详细]
author-avatar
Lcy榆
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有