zoukankan      html  css  js  c++  java
  • LCA之不知道叫什么名字 (确实不知道)

    题目

    思路

    这道题就是典型的lca板子(倍增)
    但是~~~

    调了一下午,各种快读快输,结果,换了台机子,过了??!!难道我平时水的太多了,把机子水慢了??!!

    虽然还是很慢

    附上代码

    
    
    #include<bits/stdc++.h>
    using namespace std;
    const int Size=2000000+100;
    int ver[Size],Next[Size],edge[Size],head[Size];
    int n,m,k,ans,x,y,z,now,num;
    int f[Size][23],d[Size];
    int tot,t;
    inline void add(int x,int y,int z){
    	ver[++tot]=y,edge[tot]=z,Next[tot]=head[x],head[x]=tot;
    }
    inline int read(){
    	int s=0;
    	char ch=getchar();
    	while(ch<'0'||ch>'9')ch=getchar();
    	while(ch>='0'&& ch<='9')s=(s<<3)+(s<<1)+(ch^48),ch=getchar();
    	return s;
    }
    queue<int>q;
    inline void bfs(){
    	q.push(1),d[1]=1;
    	while(q.size()){
    		int x=q.front();q.pop();
    		for(int i=head[x];i;i=Next[i]){
    			int y=ver[i];
    			if(d[y])continue;
    			d[y]=d[x]+1;
    			d[y]=d[x]+edge[i];
    			f[y][0]=x;
    			for(int j=1;j<=t;j++)
    				f[y][j]=f[f[y][j-1]][j-1];
    			q.push(y);		
    		}
    	}
    }
    inline int LCA(int x,int y){
    	if(d[x]>d[y])swap(x,y);
    	for(int i=t;i>=0;i--)
    		if(d[f[y][i]]>=d[x])y=f[y][i];
    	if(x==y)return x;
    	for(int i=t;i>=0;i--)
    		if(f[x][i]!=f[y][i])x=f[x][i],y=f[y][i];
    	return f[x][0];
    		
    }
    inline int work(int now,int x){
    	for(int i=21;i>=0;i--){
    		if(d[now]-d[f[now][i]]<=x){
    			x-=(d[now]-d[f[now][i]]);now=f[now][i];
    		}
    	}
    	return now;
    }
    int main(){
    	n=read(),now=read(),k=read();
    	t=(int)(log(n)/log(2))+1;
    	for(register int i=1;i<n;i++){
    		int x,y;
    		x=read(),y=read();
    		add(x,y,1);add(y,x,1);
    	}
    	bfs();
    	for(register int i=1;i<=k;i++){
    		int dis,to;
    		to=read();dis=read();
    		int lca=LCA(now,to);
    		if(d[now]+d[to]-2*d[lca]<=dis){
    			now=to;
    			printf("%d ",now);
    		}
    		else if(d[now]-d[lca]>=dis){
    			now=work(now,dis);
    			printf("%d ",now);
    		}
    		else{
    			now=work(to,d[now]+d[to]-2*d[lca]-dis);
    			printf("%d ",now);
    		}
    	}
    	return 0;
    }
    
    
  • 相关阅读:
    椭圆形 上传图片预览 image preview (未整理版本)
    canvas学习笔记03:简单脉冲效果
    canvas学习笔记02:饼图&柱状图
    canvas学习笔记01:Math.sin & Math.cos
    java jdk 随机数阻塞问题
    家政/保洁 平台设计
    Lock和synchronized
    jvm 中java new 对象顺序
    Java 多线程原理
    java ftp上传下载,下载文件编码设置
  • 原文地址:https://www.cnblogs.com/soda-ma/p/13262726.html
Copyright © 2011-2022 走看看