LYDSY模拟赛day2 Dash Speed


/*
弃坑
*/
#include<cstdio>
#include<algorithm>
using namespace std;
const int N=,M=N*;
int n,m,i,g[N],v[N<<],nxt[N<<],ed,cur,ans[N];
int size[N],f[N],d[N],son[N],top[N];
int fa[N],dep[N],A[N],B[N];
int G[],V[M],W[M],NXT[M],ED;
struct E{int t,x,y;E(){}E(int _t,int _x,int _y){t=_t,x=_x,y=_y;}}q[N<<];
void add(int x,int y){v[++ed]=y;nxt[ed]=g[x];g[x]=ed;}
void dfs(int x){
size[x]=;
for(int i=g[x];i;i=nxt[i])if(v[i]!=f[x]){
f[v[i]]=x,d[v[i]]=d[x]+;
dfs(v[i]),size[x]+=size[v[i]];
if(size[v[i]]>size[son[x]])son[x]=v[i];
}
}
void dfs2(int x,int y){
top[x]=y;
if(son[x])dfs2(son[x],y);
for(int i=g[x];i;i=nxt[i])if(v[i]!=son[x]&&v[i]!=f[x])dfs2(v[i],v[i]);
}
int lca(int x,int y){
for(;top[x]!=top[y];x=f[top[x]])if(d[top[x]]<d[top[y]])swap(x,y);
return d[x]<d[y]?x:y;
}
int dis(int x,int y){return d[x]+d[y]-*d[lca(x,y)];}
int F(int x){return fa[x]==x?x:F(fa[x]);}
void merge(int x,int y,int&ret){
x=F(x),y=F(y);
int u,v,t=-,tmp;
tmp=dis(A[x],B[x]);
if(tmp>t)t=tmp,u=A[x],v=B[x];
tmp=dis(A[x],A[y]);
if(tmp>t)t=tmp,u=A[x],v=A[y];
tmp=dis(A[x],B[y]);
if(tmp>t)t=tmp,u=A[x],v=B[y];
tmp=dis(B[x],A[y]);
if(tmp>t)t=tmp,u=B[x],v=A[y];
tmp=dis(B[x],B[y]);
if(tmp>t)t=tmp,u=B[x],v=B[y];
tmp=dis(A[y],B[y]);
if(tmp>t)t=tmp,u=A[y],v=B[y];
if(ret<t)ret=t;
if(dep[x]==dep[y]){
dep[x]++;
q[++cur]=E(,x,);
}
if(dep[x]<dep[y])swap(x,y);
q[++cur]=E(,y,);
q[++cur]=E(,x,A[x]);
q[++cur]=E(,x,B[x]);
fa[y]=x,A[x]=u,B[x]=v;
}
void retrace(int t){
while(cur>t){
if(!q[cur].t)dep[q[cur].x]--;
if(q[cur].t==)fa[q[cur].x]=q[cur].x;
if(q[cur].t==)A[q[cur].x]=q[cur].y;
if(q[cur].t==)B[q[cur].x]=q[cur].y;
cur--;
}
}
void ins(int x,int a,int b,int c,int d,int p,int q){
if(c<=a&&b<=d){
V[++ED]=p;
W[ED]=q;
NXT[ED]=G[x];
G[x]=ED;
return;
}
int mid=(a+b)>>;
if(c<=mid)ins(x<<,a,mid,c,d,p,q);
if(d>mid)ins(x<<|,mid+,b,c,d,p,q);
}
void solve(int x,int a,int b,int ret){
int pos=cur;
for(int i=G[x];i;i=NXT[i])merge(V[i],W[i],ret);
if(a==b){
ans[a]=ret;
retrace(pos);
return;
}
int mid=(a+b)>>;
solve(x<<,a,mid,ret);
solve(x<<|,mid+,b,ret);
retrace(pos);
}
int main(){
freopen("speed.in","r",stdin);freopen("speed.out","w",stdout);
scanf("%d%d",&n,&m);
for(i=;i<n;i++){
int x,y,l,r;
scanf("%d%d%d%d",&x,&y,&l,&r);
add(x,y),add(y,x);
ins(,,n,l,r,x,y);
}
dfs();dfs2(,);
for(i=;i<=n;i++)fa[i]=A[i]=B[i]=i;
solve(,,n,);
while(m--)scanf("%d",&i),printf("%d\n",ans[i]);
fclose(stdin);fclose(stdout);
return ;
}
LYDSY模拟赛day2 Dash Speed的更多相关文章
- LYDSY模拟赛day2 Divisors
/* 注意分解质因数,如果i是,那么n/i也是,这样就可以解决分解质因数的时间问题了 当 k ≥ 1 时,只有这些数的约数才会对答案产生贡献. 求出 m 个数的所有不超过 n 的约数,去重后统计即可. ...
- LYDSY模拟赛day2 Market
/* orz claris,这个题的解法非常巧妙,首先是时间问题,其实这个问题只要离线处理一下就可以了,把物品和询问都按照时间排序,然后看一下能不能满足.然后,因为容量<=10^9,显然是不可能 ...
- CH Round #58 - OrzCC杯noip模拟赛day2
A:颜色问题 题目:http://ch.ezoj.tk/contest/CH%20Round%20%2358%20-%20OrzCC杯noip模拟赛day2/颜色问题 题解:算一下每个仆人到它的目的地 ...
- CH Round #49 - Streaming #4 (NOIP模拟赛Day2)
A.二叉树的的根 题目:http://www.contesthunter.org/contest/CH%20Round%20%2349%20-%20Streaming%20%234%20(NOIP 模 ...
- CH Round #55 - Streaming #6 (NOIP模拟赛day2)
A.九九归一 题目:http://ch.ezoj.tk/contest/CH%20Round%20%2355%20-%20Streaming%20%236%20(NOIP模拟赛day2)/九九归一 题 ...
- LYDSY模拟赛day9 2048
/* 大模拟题,做的时候思路还是比较清晰的 */ #include<iostream> #include<cstdio> #include<string> #inc ...
- CH Round #55 - Streaming #6 (NOIP模拟赛day2)解题报告
T1九九归一 描述 萌蛋在练习模n意义下的乘法时发现,总有一些数,在自乘若干次以后,会变成1.例如n=7,那么5×5 mod 7=4,4×5 mod 7=6,6×5 mod 7=2,2×5 mod 7 ...
- PKUSC 模拟赛 day2 下午总结
终于考完了,下午身体状况很不好,看来要锻炼身体了,不然以后ACM没准比赛到一半我就挂掉了 下午差点AK,有一道很简单的题我看错题面了所以没有A掉 第一题显然是非常丝薄的题目 我们很容易通过DP来O(n ...
- 【洛谷】NOIP提高组模拟赛Day2【动态开节点/树状数组】【双头链表模拟】
U41571 Agent2 题目背景 炎炎夏日还没有过去,Agent们没有一个想出去外面搞事情的.每当ENLIGHTENED总部组织活动时,人人都说有空,结果到了活动日,却一个接着一个咕咕咕了.只有不 ...
随机推荐
- 374&375. Guess Number Higher or Lower 1&2
做leetcode的题 We are playing the Guess Game. The game is as follows: I pick a number from 1 to n. You ...
- struts2中的OGNL详解
先了解一下OGNL的概念 OGNL的全名称Object Graph Navigation Language.全称为对象图导航语言,是一种表达式语言.使用这种表达式语言,你可以通过某种表达式语法,存取J ...
- 第1章 重构,第一个案例(3):运用多态取代switch
3. 运用多态取代与价格相关的条件逻辑 3.1 switch和“常客积分”代码的再次搬迁 (1)switch:最好不要在另一个对象的属性上运用switch语句 switch(getMovie().ge ...
- Spring多种注入方式及注解实现DI
一.Bean作用域 spring容器创建的时候,会将所有配置的bean对象创建出来,默认bean都是单例的.代码通过getBean()方法从容器获取指定的bean实例,容器首先会调用Bean类的无参构 ...
- [bzoj1901][zoj2112][Dynamic Rankings] (整体二分+树状数组 or 动态开点线段树 or 主席树)
Dynamic Rankings Time Limit: 10 Seconds Memory Limit: 32768 KB The Company Dynamic Rankings has ...
- Andorid 反编译App
转载请标明出处:http://blog.csdn.net/lmj623565791/article/details/23564065 开发的过程中,有时候可能会去使用别的app里面的图片,参考布局甚至 ...
- docker创建镜像
手动创建: docker run -d -p mynginx:v2 nginx rpm -ivh http://mirrors.aliyun.com/epel/epel-release-latest- ...
- 【ASP.NET实战教程】基于ASP.NET技术下多用户博客系统全程实战开发(NNblog)
岁末主推:牛牛老师主讲,多用户博客系统,基于ASP.NET技术,年后将带来移动业务平台项目项目目标: 打造个性品牌Blogo,定制多用户博客 为每一个博客用户提供个性化的 blogo解决方案,打造精品 ...
- request.getcontextPath() 详解
request.getcontextPath() 详解 文章分类:Java编程 <%=request.getContextPath()%>是为了解决相对路径的问题,可返回站点的根路径. 但 ...
- 生成 PDF 全攻略【2】在已有PDF上添加内容
项目在变,需求在变,不变的永远是敲击键盘的程序员..... PDF 生成后,有时候需要在PDF上面添加一些其他的内容,比如文字,图片.... 经历几次失败的尝试,终于获取到了正确的代码书写方式. 在此 ...