zoukankan      html  css  js  c++  java
  • 直径+贪心——cf1294F

    /*
    在树上找三个点,似的这三个形成的路径覆盖边数最多
    结论:一定是直径+直径上最深的叶子 
    把直径拉出来,然后直径上每个结点dfs一次就可以 
    */
    #include<bits/stdc++.h>
    using namespace std;
    #define N 400005
    
    vector<int>G[N];
    int n,s,t,d[N],vis[N],id,Max;
    
    void getdeep(int u,int pre){
        for(auto v:G[u]){
            if(v==pre)continue;
            d[v]=d[u]+1;
            getdeep(v,u);
        }
    }
    
    vector<int>path;
    int getpath(int u,int pre){
        int flag=0;
        if(u==t){path.push_back(u);return 1;}
        for(auto v:G[u]){
            if(v==pre)continue;
            if(getpath(v,u))
                flag=1;
        }
        
        if(flag)path.push_back(u);
        return flag;
    }
    
    void dfs(int u,int pre){
        for(auto v:G[u]){
            if(vis[v] || v==pre)continue;
            d[v]=d[u]+1;
            dfs(v,u);
        }
    }
    
    int main(){
        cin>>n;
        for(int i=1;i<n;i++){
            int u,v;scanf("%d%d",&u,&v);
            G[u].push_back(v);
            G[v].push_back(u);
        }    
        s=1;
        getdeep(s,s);
        for(int i=1;i<=n;i++)
            if(d[i]>d[s])s=i;
        
        memset(d,0,sizeof d);
        getdeep(s,s);
        for(int i=1;i<=n;i++)
            if(d[i]>d[t])t=i;
        int ans=d[t];
            
        getpath(s,s);
    //    for(auto x:path)cout<<x<<" ";
        memset(d,0,sizeof d);
        for(auto x:path)vis[x]=1;
        for(auto x:path)dfs(x,x);
        Max=-1;
        for(int i=1;i<=n;i++)if(!vis[i]){
            if(Max<d[i])Max=d[i],id=i;
        }
        if(Max==-1){
            for(int i=1;i<=n;i++) 
                if(i!=s && i!=t)id=i;
            Max=0;
        }
        ans+=Max;
        
        cout<<ans<<'
    ';
        cout<<s<<" "<<t<<" "<<id<<'
    ';
    } 
  • 相关阅读:
    SpringAOP-基于@AspectJ的简单入门
    SpringAOP-切面优先级
    Commons_IO_FileUtils的使用
    java_IO_装饰器
    java_IO_3
    java_IO_2
    java_IO_1
    App Inventor
    java学习_5_24
    java学习_5_23
  • 原文地址:https://www.cnblogs.com/zsben991126/p/12259451.html
Copyright © 2011-2022 走看看