• OpenJudge 1031 Lausanne Capitale Olympique


    Lausanne Capitale Olympique

    Time Limit: 1000ms
    Memory Limit: 65536KB
    This problem will be judged on OpenJudge. Original ID: 1031
    64-bit integer IO format: %lld      Java class name: Main
     

    Lausanne is a city in the French-speaking part of Switzerland. The headquarters of the International Olympic Committee (IOC) are located here; therefore Lausanne is also called the Olympic Capital.

    As the London 2012 Olympics is coming, the IOC members frequently come to Lausanne to have meetings. Fortunately, IOC has a partner Lausanne Airways, which provides the IOC members with free flights.

    Nevertheless, the IOC members live all over the world, and flights of Lausanne Airways are limited, so sometimes several transfers are unavoidable. For example, if a member lives in Shanghai, maybe he needs first fly to Beijing, then Paris, then Geneva, and finally arrived in Lausanne, which contains 3 transfers.

    For convenience’s sake, the IOC members will always choose the trip with the minimum transfer times. However, due to the bad weather, some flights may be canceled, thus some members’ trip must be rescheduled. Lausanne Airways predicts that if there is only one flight canceled, then the minimum transfer times increases at most one for any IOC member.

    Please check whether the above prediction is accomplished. Please note that all the flights mentioned above are two-way.

     

    Input

    The first line contains two integers nm (1 ≤ n ≤ 10000, 1 ≤ m ≤ 100000), indicates that the IOC members live in n different cities, numbered from 1 to n, which 1 stands for Lausanne and 2~n for other cities.
    Then there follows m lines, each of them contains two integers x, y (1 ≤ x, y ≤ n, x ≠ y), indicates there is a flight between city x and city y. It is guaranteed that there is at most one flight between any two cities, and these n cities are connected.
     

    Output

    If the prediction is accomplished, output 1; otherwise output 0.
    If after a certain flight being canceled, these n cities are no longer connected, also output 0.
     

    Sample Input

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

    Sample Output

    0

    解题:。。哈哈,假设去掉边u->v,那么1到v就要改道,长度不能大于1啊,如果能够到v的变长不超过1,那么经过v的其他道路最长也不会增加超过1.

    所以,看v的邻边,如果可以从v的邻点到此,那么就好了,要满足增长不大于1,那么1到v的邻点的长度应该为d[v]或者为d[v]-1。。。好了,直接枚举点的邻点就好了。。。

     1 #include <iostream>
     2 #include <cstdio>
     3 #include <cstring>
     4 #include <cmath>
     5 #include <algorithm>
     6 #include <climits>
     7 #include <vector>
     8 #include <queue>
     9 #include <cstdlib>
    10 #include <string>
    11 #include <set>
    12 #include <stack>
    13 #define LL long long
    14 #define pii pair<int,int>
    15 #define INF 0x3f3f3f3f
    16 using namespace std;
    17 const int maxn = 10010;
    18 struct arc{
    19     int to,next;
    20     arc(int x = 0,int y = -1){
    21         to = x;
    22         next = y;
    23     }
    24 };
    25 arc e[maxn*20];
    26 int head[maxn],d[maxn],q[maxn*10];
    27 int tot,n,m;
    28 bool done[maxn];
    29 void add(int u,int v){
    30     e[tot] = arc(v,head[u]);
    31     head[u] = tot++;
    32     e[tot] = arc(u,head[v]);
    33     head[v] = tot++;
    34 }
    35 void bfs(){
    36     int hd = 0,tl = 0;
    37     for(int i = 1; i <= n; ++i) d[i] = INF;
    38     d[1] = 0;
    39     q[tl++] = 1;
    40     while(hd < tl){
    41         int u = q[hd++];
    42         for(int i = head[u]; ~i; i = e[i].next){
    43             if(d[e[i].to] > d[u] + 1){
    44                 d[e[i].to] = d[u] + 1;
    45                 q[tl++] = e[i].to;
    46             }
    47         }
    48     }
    49 }
    50 int main() {
    51     int u,v;
    52     while(~scanf("%d %d",&n,&m)){
    53         memset(head,-1,sizeof(head));
    54         for(int i = tot = 0; i < m; ++i){
    55             scanf("%d %d",&u,&v);
    56             add(u,v);
    57         }
    58         bfs();
    59         bool ans = true;
    60         for(int i = 2; ans && i <= n; ++i){
    61             int cnt = 0;
    62             for(int k = head[i]; ~k; k = e[k].next)
    63                 if(d[e[k].to] <= d[i] && ++cnt > 2) break;
    64             if(cnt < 2) ans = false;
    65         }
    66         printf("%d
    ",ans);
    67     }
    68     return 0;
    69 }
    View Code
  • 相关阅读:
    SVN服务的配置与管理
    SVN配置多仓库与权限控制
    SVN使用详解
    这个问题他又来了,如何学编程!
    乘风破浪的程序员们
    Java 学习路线(史上最全 2020 版 ~ 持续更新中)
    P4782 【模板】2-SAT 问题
    HDU
    2020.8.3
    Interesting Computer Game
  • 原文地址:https://www.cnblogs.com/crackpotisback/p/4101731.html
Copyright © 2020-2023  润新知