题目描述

Mr. Walker 最近在研究树,尤其是最长树链问题。现在树中的每个点都有一个值,他想在树中找出最长的链,使得这条链上对应点的值的最大公约数不等于1。请求出这条最长的树链的长度。

输入格式

第一行一个整数 n,表示点的个数。

接下来 n−1 行,每行两个整数 x,y 表示 x,y 之间有边。

数据保证给出的是一棵树。

接下来一行 n 个整数表示每个点对应的权值 ai​。

输出格式

输出一个整数,表示这条树链的长度。

样例

样例输入

4

1 2

1 3

2 4

6 4 5 2

样例输出

3

数据范围与提示

n<=10^5,1<= ai<=10^9。

【题解】

做这类题一定要记住这句话:

没有暴力解决不了的题,只有不敢写暴力的人!

咳咳,所以说,这题的正解正是暴力。

读完题后,我们不难想到这样一个暴力:枚举每一个质数,权值是这个质数的倍数的节点设为1,最长链的长度就是点权为1的点构成的最长的链。

如果枚举所有质数,这题就会变成n*n,一定是A不了的,那怎么办呢?方法是这样的。

每个数最多只有log个不同的质因数,所以只要把所有点权质因数分解,枚举出现的质数就可以了。

我们枚举完质因数后dfs,因为每个点最多有log个不同的质因数,所以复杂度大概是O(能过)O(nlogn)。

【题外话】

这么写有一些小问题,如果质数极大就会T,Loj是能A的(数据真垃圾),但吕神的数据比较优秀,把我卡成了75.

这题告诉我:永远不要被数据吓到,也永远不要放弃一题,万一打个暴力能A呢?

下贴本蒟蒻丑陋的代码

#include<iostream>
#include<cstdio>
#include<cstring>
#include<cmath>
#include<algorithm>
#include<queue>
#include<vector>
using namespace std;
const int N=;
int n,con,ans=,h[N],cnt,a[N],p[N],dis[N];
bool v[N];
struct
{
int nex,to;
}e[N<<]; void dfs(int u,int b,int c)
{
dis[u]=;
for(int i=h[u];i;i=e[i].nex)
if(e[i].to!=b && a[e[i].to]%c==)
{
while(a[e[i].to]%c==)
a[e[i].to]/=c;
dfs(e[i].to,u,c);
ans=max(ans,dis[u]+dis[e[i].to]+);
dis[u]=max(dis[u],dis[e[i].to]);
}
dis[u]++;
} void add(int u,int v)
{
cnt++;
e[cnt].nex=h[u];
e[cnt].to=v;
h[u]=cnt;
} int main()
{ scanf("%d",&n);
for(int i=;i*i<=;i++)
if(v[i]==)
{
for(int j=i*i;j<;j+=i) v[j]=;
}
for(int i=;i<=;i++)
if(v[i]==)
p[++con]=i;
for(int i=;i<n;i++)
{
int x,y;
scanf("%d%d",&x,&y);
add(x,y);add(y,x);
}
for(int i=;i<=n;i++)
scanf("%d",&a[i]);
for(int i=;i<=n;i++)
{
int s=a[i];
for(int j=;j<=con && p[j]*p[j]<=a[i];j++)
{
if(s%p[j]==)
{
while(s%p[j]==)
s/=p[j];
dfs(i,,p[j]);
}
}
if(s>)
dfs(i,,s);
a[i]=;
}
printf("%d",ans);
return ;
}

oi路漫漫,愿此题解能助你一臂之力......

「美团 CodeM 初赛 Round A」最长树链的更多相关文章

  1. 【填坑】loj6159. 「美团 CodeM 初赛 Round A」最长树链

    水一水 枚举各个质数,把是这个数倍数的点留下,跑直径,没了 #include <bits/stdc++.h> using namespace std; int h,t,n,p,q,M,N; ...

  2. #6164. 「美团 CodeM 初赛 Round A」数列互质-莫队

    #6164. 「美团 CodeM 初赛 Round A」数列互质 思路 : 对这个题来言,莫队可以 n*根号n 离线处理出各个数出现个的次数 ,同时可以得到每个次数出现的次数 , 但是还要处理有多少 ...

  3. loj #6177. 「美团 CodeM 初赛 Round B」送外卖2 状压dp floyd

    LINK:#6177.美团 送外卖2 一道比较传统的状压dp题目. 完成任务 需要知道自己在哪 已经完成的任务集合 自己已经接到的任务集合. 考虑这个dp记录什么 由于存在时间的限制 考虑记录最短时间 ...

  4. 【loj6177】「美团 CodeM 初赛 Round B」送外卖2 Floyd+状压dp

    题目描述 一张$n$个点$m$条边的有向图,通过每条边需要消耗时间,初始为$0$时刻,可以在某个点停留.有$q$个任务,每个任务要求在$l_i$或以后时刻到$s_i$接受任务,并在$r_i$或以前时刻 ...

  5. Loj #6164. 「美团 CodeM 初赛 Round A」数列互质

    link : https://loj.ac/problem/6164 莫队傻题,直接容斥做. #include<bits/stdc++.h> #define maxn 100005 #de ...

  6. LiberOJ#6178. 「美团 CodeM 初赛 Round B」景区路线规划 概率DP

    题意 游乐园被描述成一张 n 个点,m 条边的无向图(无重边,无自环).每个点代表一个娱乐项目,第 i 个娱乐项目需要耗费 ci 分钟的时间,会让小 y 和妹子的开心度分别增加 h1i ,h2i ,他 ...

  7. 「美团 CodeM 初赛 Round A」试题泛做

    最长树链 树形DP.我们发现gcd是多少其实并不重要,只要不是1就好了,此外只要有一个公共的质数就好了.计f[i][j]表示i子树内含有j因子的最长链是多少.因为一个数的不同的质因子个数是log级别的 ...

  8. loj6177 「美团 CodeM 初赛 Round B」送外卖2 最短路+状压dp

    题目传送门 https://loj.ac/problem/6177 题解 一直不知道允不允许这样的情况:取了第一的任务的货物后前往配送的时候,顺路取了第二个货物. 然后发现如果不可以这样的话,那么原题 ...

  9. [美团 CodeM 初赛 Round A]数列互质

    题目大意: 给出一个长度为n的数列a1,a2,a3,...,an,以及m组询问(li,ri,ki),求区间[li,ri]中有多少数在该区间中的出现次数与ki互质. 思路: 莫队. f[i]记录数字i出 ...

随机推荐

  1. 最终还是选择了markdownpad2

    markdownpad2使用 最终 哈哈,最后还是选择了markdownpad2,经过探索才知道这个玩意多么好用. 点击,下载. 碰到的问题 1.win10出现HTML无法渲染得对话框 结果是,官网有 ...

  2. bzoj 4591 [Shoi2015]超能粒子炮·改——组合数前缀和

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=4591 先说说自己的想法: 从组合意义的角度考虑,从n个里选<=k个,就添加k个空位置, ...

  3. Salesforce注册教程

    打开网址 https://developer.salesforce.com/,点击右上角的Sign up(注册) 在页面输入基本信息 >Name:First(姓名) Last(姓)  >E ...

  4. Java实现Bag类

    Java实现Bag类 import java.util.Iterator; import java.util.NoSuchElementException; import java.util.Scan ...

  5. MySQL 采用Xtrabackup对数据库进行全库备份

    1,xtrabackup简介 关于数据库备份以及备份工具,参考:http://blog.itpub.net/26230597/viewspace-1460065/,这里来介绍xtrabackup已经如 ...

  6. 在Linux上利用core dump和GDB调试segfault

    时常会遇到段错误(segfault),调试非常费劲,除了单元测试和基本测试外,有些时候是在在线环境下,没有基本开发和测试工具,这就需要调试的技能.以前介绍过使用strace进行系统调试和追踪<l ...

  7. 静默安装Azure CLI

    Azure的CLI目前已经是基于Python的2.0版本.其信息在下面的链接可以找到: https://github.com/Azure/azure-cli 其安装方法可以根据网站上描述的命令实现: ...

  8. 免费的xshell下载

    平时从网站上下载的xshell,都是有有效期的,用一个月就生效了 所以我们可以这样: 学习源头: https://blog.csdn.net/zhoukikoo/article/details/794 ...

  9. Object-C类、方法、构造函数(2)

    Object-C 代码分为三部分:.h文件..m文件及调用文件 .h源文件 #import <Foundation/Foundation.h> @interface Student:NSO ...

  10. 蘑菇街 IM 项目 TeamTalk

    源码 https://github.com/mogujie/TeamTalk 试用 http://tt.mogu.io/