zoukankan      html  css  js  c++  java
  • CSU 1659: Graph Center(SPFA)

    1659: Graph Center

    Time Limit: 1 Sec  Memory Limit: 128 MB
    Submit: 63  Solved: 25
    [Submit][Status][Web Board]

    Description

    The center of a graph is the set of all vertices of minimum eccentricity, that is, the set of all vertices A where the greatest distance d(A,B) to other vertices B is minimal. Equivalently, it is the set of vertices with eccentricity equal to the graph's radius. Thus vertices in the center (central points) minimize the maximal distance from other points in the graph.
                                                                                                                 ------wikipedia
    Now you are given a graph, tell me the vertices which are the graph center.

    Input

    There are multiple test cases.
    The first line will contain a positive integer T (T ≤ 300) meaning the number of test cases.
    For each test case, the first line contains the number of vertices N (3 ≤ N ≤ 100) and the number of edges M (N - 1 ≤ N * (N - 1) / 2). Each of the following N lines contains two vertices x (1 ≤ x ≤ N) and y (1 ≤ y ≤ N), meaning there is an edge between x and y.

    Output

    The first line show contain the number of vertices which are the graph center. Then the next line should list them by increasing order, and every two adjacent number should be separated by a single space.

    Sample Input

    2
    4 3
    1 3
    1 2
    2 4
    5 5
    1 4
    1 3
    2 4
    2 3
    4 5
    

    Sample Output

    2
    1 2
    3
    1 2 4
    

    HINT

    Source

    #include<stdio.h> 
    #include<queue> 
    #include<string.h> 
    using namespace std; 
      
    const int MAXN = 105; 
    const int MAXM = 100005; 
    const int INF = 1<<30; 
    struct EDG{ 
        int to,next; 
    }edg[MAXM]; 
    int eid,head[MAXN]; 
      
    void init(){ 
        eid=0; 
        memset(head,-1,sizeof(head)); 
    } 
    void addEdg(int u,int v){ 
        edg[eid].to=v; edg[eid].next=head[u]; head[u]=eid++; 
        edg[eid].to=u; edg[eid].next=head[v]; head[v]=eid++; 
    } 
    int spfa(int s,int n){ 
        queue<int>q; 
        bool inq[MAXN]={0}; 
        int d[MAXN]; 
        for(int i=1; i<=n; i++) 
            d[i]=INF; 
        d[s]=0; 
        q.push(s); 
        while(!q.empty()){ 
            int u=q.front(); q.pop(); 
            inq[s]=0; 
            for(int i=head[u]; i!=-1; i=edg[i].next){ 
                int v=edg[i].to; 
                if(d[v]>d[u]+1){ 
                    d[v]=d[u]+1; 
                    if(!inq[v]) 
                     q.push(v),inq[v]=1; 
                } 
            } 
        } 
        int maxt=0; 
        for(int i=1; i<=n; i++) 
            if(maxt<d[i]) 
             maxt=d[i]; 
        return maxt; 
    } 
    int main(){ 
        int T,n,m,u,v,d[MAXN],id[MAXN]; 
        scanf("%d",&T); 
        while(T--){ 
            scanf("%d%d",&n,&m); 
            init(); 
            while(m--){ 
                scanf("%d%d",&u,&v); 
                addEdg(u,v); 
            } 
            int mint=INF; 
            for(int i=1;i<=n;i++){ 
                d[i]=spfa(i,n); 
                if(d[i]<mint) 
                mint=d[i]; 
            } 
            int k=0; 
            for(int i=1; i<=n; i++) 
             if(mint==d[i]){ 
                id[k++]=i; 
             } 
             printf("%d
    ",k); 
             for(int i=0; i<k; i++){ 
                printf("%d",id[i]); 
                if(i!=k-1) 
                 printf(" "); 
                else
                printf("
    "); 
             } 
        } 
    } 
      
    /************************************************************** 
        Problem: 1659 
        User: aking2015 
        Language: C++ 
        Result: Accepted 
        Time:256 ms 
        Memory:1848 kb 
    ****************************************************************/ 
    


  • 相关阅读:
    Python 之 编程中常见错误
    Python 列表(数组)初识
    Python 字符串处理
    QT学习笔记三 窗口类型
    C++ Primer第五版学习笔记十 引用与指针
    C++ Primer第五版学习笔记九 变量及初始化,声明和定义,作用域
    angularf封装echarts
    记录npm yarn安装遇到的问题
    网页中嵌入google地图
    og协议-有利于SNS网站分享
  • 原文地址:https://www.cnblogs.com/mengfanrong/p/5123869.html
Copyright © 2011-2022 走看看