秀秀的森林(forest)

题目要求树上两条不相交的链,且要求权值的和最大

性质:

1.如果某棵树上的最长链端点为x,y,则该树上任意一点z出发的最长链为max(xz,zy)

2如果两个点被连进了树里,那么他们的lca也一定被连进了树里、

有了这个,合并就很好做了

假设合并A,B两棵树,最长链端点为ax,ay ,bx,by

比较两两相连的答案取max即可

#include<cstdio>
#include<iostream>
#include<cstdlib>
#include<cstring>
#include<algorithm>
#include<cmath>
#define maxn 100005
#define ll long long
#define mod 1000000007
using namespace std;
int n,head[maxn],s[maxn],id[maxn],f[maxn][21],t1,t2,tot=1;
int x[maxn],y[maxn],v[maxn],ans,f1,f2,be[maxn];
int deep[maxn],d[maxn];
ll A[maxn];
struct node{
int v,nex;
}e[maxn*2];
void lj(int t1,int t2){
e[++tot].v=t2;e[tot].nex=head[t1];head[t1]=tot;
}
void dfs(int k,int fa){
f[k][0]=fa;deep[k]=deep[fa]+1;d[k]=d[fa]+s[k];
for(int i=head[k];i;i=e[i].nex){
if(e[i].v!=fa)dfs(e[i].v,k);
}
}
int getf(int k){
if(be[k]==k)return k;
be[k]=getf(be[k]);return be[k];
}
int Lca(int a,int b){
if(deep[a]<deep[b])swap(a,b); for(int x=20;x>=0;x--)if(deep[f[a][x]]>=deep[b])a=f[a][x];
for(int x=20;x>=0;x--)if(f[a][x]!=f[b][x])a=f[a][x],b=f[b][x]; if(a==b)return a;
else return f[a][0];
}
int Len(int a,int b){
int lca=Lca(a,b);
return d[a]+d[b]-d[lca]-d[f[lca][0]];
}
ll work(int k,int num){
ll ss=1,p=k;
while(num){
if(num&1)ss=ss*p;
p=p*p;p%=mod;ss=ss%mod;num>>=1;
}
return ss;
}
int main()
{
cin>>n;
for(int i=1;i<=n;i++)scanf("%d",&s[i]);
for(int i=1;i<n;i++){
scanf("%d%d",&t1,&t2);
lj(t1,t2);lj(t2,t1);
}
for(int i=1;i<n;i++)scanf("%d",&id[i]);
dfs(1,0);
for(int j=1;j<=20;j++)
for(int i=1;i<=n;i++)f[i][j]=f[f[i][j-1]][j-1];
ll ans=1;
for(int i=1;i<=n;i++){
x[i]=y[i]=i;v[i]=s[i];ans=ans*s[i]%mod;
be[i]=i;
}
A[n]=ans;
for(int num=n-1;num>=1;num--){
int t1=e[id[num]*2].v,t2=e[id[num]*2+1].v;
if(f[t1][0]!=t2)swap(t1,t2);
f1=getf(t1);f2=getf(t2);be[f1]=f2;
int ax=x[f1],ay=y[f1],bx=x[f2],by=y[f2];
int ansx,ansy,ansv,T;
if(v[f1]>v[f2])ansv=v[f1],ansx=ax,ansy=ay;
else ansv=v[f2],ansx=bx,ansy=by;
T=Len(ax,bx);if(T>ansv)ansv=T,ansx=ax,ansy=bx;
T=Len(ax,by);if(T>ansv)ansv=T,ansx=ax,ansy=by;
T=Len(ay,bx);if(T>ansv)ansv=T,ansx=ay,ansy=bx;
T=Len(ay,by);if(T>ansv)ansv=T,ansx=ay,ansy=by;
ans=ans*work(v[f1],mod-2)%mod*work(v[f2],mod-2)%mod;
v[f2]=ansv;x[f2]=ansx,y[f2]=ansy;
//cout<<ansx<<' '<<ansy<<' '<<ansv<<' '<<Lca(ansx,ansy)<<endl;
ans=ans*ansv%mod;A[num]=ans;
//cout<<ans<<' '<<ansv<<endl;
}
for(int i=1;i<=n;i++)printf("%lld\n",A[i]);
return 0;
}

秀秀的森林(forest)的更多相关文章

  1. 【题解】10-19秀秀的森林(forest)

    我恨秀秀倍增LCA+离线 (时光倒流) 题目 秀秀有一棵带n个顶点的树T,每个节点有一个点权ai-.有一天,她想拥有两棵树,于是她从T中删去了一条边.第二天,她认为三棵树或许会更好一些.因此,她又从她 ...

  2. [Python]Codecombat攻略之远边的森林Forest(1-40关)

    首页:https://cn.codecombat.com/play语言:Python 第二界面:远边的森林Forest(40关)时间:2-6小时内容:if/else.关系操作符.对象属性.处理输入网页 ...

  3. [Python] Codecombat攻略 远边的森林 Forest (1-40关)

    首页:https://cn.codecombat.com/play语言:Python 第二界面:远边的森林Forest(40关)时间:2-6小时内容:if/else.关系操作符.对象属性.处理输入网页 ...

  4. 2017-10-18 NOIP模拟赛

    纸牌游戏 #include<iostream> #include<cstdio> #include<ctime> #include<cstdlib> # ...

  5. Atitit 常见的树形结构 红黑树  二叉树   B树 B+树  Trie树 attilax理解与总结

    Atitit 常见的树形结构 红黑树  二叉树   B树 B+树  Trie树 attilax理解与总结 1.1. 树形结构-- 一对多的关系1 1.2. 树的相关术语: 1 1.3. 常见的树形结构 ...

  6. kaggle之泰坦尼克的沉没

    Titanic 沉没 参见:https://github.com/lijingpeng/kaggle 这是一个分类任务,特征包含离散特征和连续特征,数据如下:Kaggle地址.目标是根据数据特征预测一 ...

  7. 【C#数据结构系列】树和二叉树

    线性结构中的数据元素是一对一的关系,树形结构是一对多的非线性结构,非常类似于自然界中的树,数据元素之间既有分支关系,又有层次关系.树形结构在现实世界中广泛存在,如家族的家谱.一个单位的行政机构组织等都 ...

  8. 【数据结构与算法】002—树与二叉树(Python)

    概念 树 树是一类重要的非线性数据结构,是以分支关系定义的层次结构 定义: 树(tree)是n(n>0)个结点的有限集T,其中: 有且仅有一个特定的结点,称为树的根(root) 当n>1时 ...

  9. NOIP2018提高组模拟题(五)

    字符串(string) Description 小林与亮亮正在做一个游戏.小林随意地写出一个字符串,字符串只由大写 字母组成,然后指定一个非负整数 m,亮亮可以进行至多 m 次操作,每次操作 为交换相 ...

随机推荐

  1. MicroService 微服务提供者搭建

    本机IP为  192.168.1.102 1.  新建Maven项目   microservice 2.   pom.xml <project xmlns="http://maven. ...

  2. CentOS系统下安装Redis

    1. 安装C语言环境 yum install gcc-c++ 2.下载Redis安装包 http://download.redis.io/releases/redis-3.2.9.tar.gz 3.解 ...

  3. spring-boot自定义启动端口

    有时候我们可能需要启动不止一个SpringBoot,而SpringBoot默认的端口号是8080,所以这时候我们就需要修改SpringBoot的默认端口了.修改SpringBoot的默认端口有两种方式 ...

  4. 【luogu P1637 三元上升子序列】 题解

    题目链接:https://www.luogu.org/problemnew/show/P1637 BIT + 离散化. 读题得数据规模需离散化.BIT开不到longint这么大的数组. 对于题目所求的 ...

  5. Excel自动从身份证中提取生日、性别、年龄

    现在学生的身份证号已经全部都是18位的新一代身份证了,里面的数字都是有规律的.前6位数字是户籍所在地的代码,7-14位就是出生日期.第17位“2”代表的是性别,偶数为女性,奇数为男性.我们要做的就是把 ...

  6. Nodejs:Node.js模块机制小结

    今天读了<深入浅出Nodejs>的第二章:模块机制.现在做一个简单的小结. 序:模块机制大致从这几个部分来讲:JS模块机制的由来.CommonJS AMD CMD.Node模块机制和包和n ...

  7. [BZOJ] 3875: [Ahoi2014&Jsoi2014]骑士游戏

    设\(f[x]\)为彻底杀死\(x\)号怪兽的代价 有转移方程 \[ f[x]=min\{k[x],s[x]+\sum f[v]\} \] 其中\(v\)是\(x\)通过普通攻击分裂出的小怪兽 这个东 ...

  8. Centos 6版本Device eth0 does not seem to be present,delaying initialization.故障处理

    1.1  故障现象 2019年06月14日晚上,公司项目组说有台业务服务器连接不上,比较着急,我通过vpn拨入的方式远程登录到管理控制台查看发现网卡没有获取到IP地址,我尝试重启来重新启动,重启的时候 ...

  9. Spring中注解大全和应用

    @Controller@RestController:@Service@Autowired@RequestMapping@RequestParam@ModelAttribute@Cacheable@C ...

  10. 09.1.VUE学习之watch监听属性变化实现类百度搜索栏功能ajax异步请求数据,返回数组

    09.1html里 <!DOCTYPE html> <html> <head> <meta charset="utf-8"> < ...