题意:一棵树,每个点都有自己val(1 <= val <= 1e5),而任意两个点u,v可以对lca(u,v) 产生gcd(valu,valv)的贡献,求每个点能接受到来自子树贡献的最大值。

分析:一个数w和其整数数倍的数gcd值还是w。记录每个值对应树的下标,枚举1- max{val}中的数,遍历其整数倍中两两结点的lca,检查其是否需要被更新。

其中遍历LCA的操作并不用二重循环枚举顶点,可以将顶点按dfs序排序后遍历其中相邻两点的LCA。

这里使用了RMQ的方式O(1) 查询LCA。

#include<bits/stdc++.h>
using namespace std;
typedef long long LL;
const int N=1e5+;
struct node{
int v,next;
}edges[N<<];
int head[N],e;
int id[N];
int RMQ[N*][];
int curID;
int F[N*],B[N*];
int n,m,Q,root;
int val[N];
int res[N];
vector<int> num[N];
int mx; void init(){
e = ; curID = ;
memset(head,-,sizeof(head));
for(int i=;i<N;++i) num[i].clear();
} void Add (int u,int v)
{
edges[e].v=v;
edges[e].next=head[u];
head[u]=e++;
} void DFS (int u,int p,int Dep)
{
int i,v;
curID++;
F[curID]=u;
B[curID]=Dep;
id[u]=curID;
for (i=head[u];i!=-;i=edges[i].next){
v=edges[i].v;
if (v==p) continue;
DFS(v,u,Dep+);
curID++;
F[curID]=u;
B[curID]=Dep;
}
} void initRMQ()
{
int i,j,x,y;
for (i=;i<=curID;i++)
RMQ[i][]=i;
for (j=;(<<j)<=curID;j++)
for (i=;i+(<<j)-<=curID;i++){
x=RMQ[i][j-];
y=RMQ[i+(<<(j-))][j-];
RMQ[i][j]=B[x]<B[y]?x:y;
}
} int getLCA (int a,int b)
{
int k,x,y;
a=id[a];b=id[b];
if (a>b) k=a,a=b,b=k;
k = - __builtin_clz(b - a + );
x=RMQ[a][k];
y=RMQ[b-(<<k)+][k];
return B[x]<B[y]?F[x]:F[y];
} void gao(int w)
{
vector<int> p;
for(int i=w;i<=mx;i+=w){
for(auto &v:num[i]){
p.push_back(v);
}
}
sort(p.begin(),p.end(),[&](int x,int y){return id[x]<id[y];});
for(int i=;i<p.size();++i){
int lca= getLCA(p[i],p[i-]);
res[lca] = max(res[lca],w);
}
} int main()
{
#ifndef ONLINE_JUDGE
freopen("in.txt","r",stdin);
freopen("out.txt","w",stdout);
#endif
int N;
while(~scanf("%d",&N)){
init();
memset(res,-,sizeof(res));
int u,v,tmp;
for(int i=;i<=N;++i){
scanf("%d",&u);
Add(u,i);
Add(i,u);
}
DFS(,-,);
initRMQ();
mx = -;
for(int i=;i<=N;++i){
scanf("%d",&val[i]);
mx = val[i]>mx? val[i] : mx;
num[val[i]].push_back(i);
}
for(int i=mx;i>=;--i)
gao(i);
for(int i=;i<=N;++i)
printf("%d\n",res[i]);
}
return ;
}

HDU - 6430 Problem E. TeaTree 2018 Multi-University Training Contest 10 (LCA+枚举因子)的更多相关文章

  1. HDU 6430 Problem E. TeaTree(虚树)

    Problem E. TeaTree Problem Description Recently, TeaTree acquire new knoledge gcd (Greatest Common D ...

  2. HDU - 6435 Problem J. CSGO 2018 Multi-University Training Contest 10 (二进制枚举+思维)

    题意:有N个主武器(MW)和M个副武器(SW),每个武器都有自己的S值,和K个附加属性xi.要选取一对主副武器搭配,搭配后获得的性能由该公式得出: 求获得最大的性能为多少. 分析:由于|xm - xs ...

  3. 2018 Nowcoder Multi-University Training Contest 10

    Practice Link J. Rikka with Nickname 题意: 给出\(n\)个字符串,要求依次合并两个串\(s, t\),满足将\(t\)合并到\(s\)中变成\(r\),使得\( ...

  4. hdu 5416 CRB and Tree(2015 Multi-University Training Contest 10)

    CRB and Tree                                                             Time Limit: 8000/4000 MS (J ...

  5. 2015 Multi-University Training Contest 10 hdu 5406 CRB and Apple

    CRB and Apple Time Limit: 12000/6000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)To ...

  6. 2015 Multi-University Training Contest 10 hdu 5412 CRB and Queries

    CRB and Queries Time Limit: 12000/6000 MS (Java/Others)    Memory Limit: 131072/131072 K (Java/Other ...

  7. 2018 Multi-University Training Contest 10 Solution

    A - Problem A.Alkane 留坑. B - Problem B. Beads 留坑. C - Problem C. Calculate 留坑. D - Problem D. Permut ...

  8. HDU 6141 - I am your Father! | 2017 Multi-University Training Contest 8

    思路来自 FXXL 最小树形图模板用kuangbin的 /* HDU 6141 - I am your Father! [ 最小树形图 ] | 2017 Multi-University Traini ...

  9. HDU - 6437 Problem L.Videos 2018 Multi-University Training Contest 10 (最小费用最大流)

    题意:M个影片,其属性有开始时间S,结束时间T,类型op和权值val.有K个人,每个人可以看若干个时间不相交的影片,其获得的收益是这个影片的权值val,但如果观看的影片相邻为相同的属性,那么收益要减少 ...

随机推荐

  1. tomcat修改默认端口

    1.webserver: tomcat2.version:   Apache Tomcat/7.0.293.operation: 修改默认端口 3.1 修改tomcat目录下的/conf/server ...

  2. 什么是 end-to-end 神经网络?——知乎解答

    什么是 end-to-end 神经网络? https://www.zhihu.com/question/51435499 解答1 张旭 像机器一样学习,像人一样生活 YJango 等   端到端指的是 ...

  3. Python之Matplotlib库常用函数大全(含注释)

    plt.savefig(‘test’, dpi = 600) :将绘制的图画保存成png格式,命名为 test plt.ylabel(‘Grade’) :  y轴的名称 plt.axis([-1, 1 ...

  4. List、Map、Set三个接口存储元素时各有什么特点?

    List.Map.Set三个接口存储元素时各有什么特点? 解答: 1)List是有序的Collection,使用此接口能够精确的控制每个元素插入的位置.用户能够使用索引(元素在List中的位置,类似于 ...

  5. 【vijos】1543 极值问题(数论+fib数)

    https://vijos.org/p/1543 好神奇的一题.. 首先我竟然忘记n可以求根求出来,sad. 然后我打了表也发现n和m是fib数.. 严格证明(鬼知道为什么这样就能对啊,能代换怎么就能 ...

  6. Linux动态库搜索路径的技巧

    众所周知,Linux动态库的默认搜索路径是/lib和/usr/lib.动态库被创建后,一般都复制到这两个目录中.当程序执行时需要某动态库,并且该动态库还未加载到内存中,则系统会自动到这两个默认搜索路径 ...

  7. VC++6.0 打开原来工程突然特别慢或者打不开?

    VC++6.0打开原来工程突然特别慢或者打不开?    近几日,对原来工程做了一些修改,感觉打开特别慢,甚至打不开,在Loading Workspace时就卡住了. 解决办法:删除工程文件中的三个文件 ...

  8. 【转载】如何升级linux上的gcc到最新版本

    来自:http://www.cppfans.org/1719.html 由于工作主要平台换到了linux上,而linux因为源上没有比较新的gcc,只有4.7,而我们用到了C++11, 只好自己升级了 ...

  9. iOS-如何在项目中使用CocoaPods

    1.打开终端. 2.将项目文件夹拖入到cd空格 后面. 3.回车,看下现在的路径是. 4.我们输入vim podfile回车,建立Podfile文件. 5.进到这个界面,我们再按i编辑--你会看到下面 ...

  10. java高精度hdu4043

    可以推出公式 f[n]=f[n-1]+f[n-1]*2*(n-1) f[1]=1; 数据量很大,最后又要进行gcd操作,java里竟然自带了一个gcd的函数,为了避免求大数取余和大数除法操作,还是用j ...