• CodeForcs 1169B Good Triple


    CodeForcs 1169B Good Triple

    题目链接:http://codeforces.com/problemset/problem/1169/B

    题目描述:给你m对不超过n的数字,找出一对x,y,满足在这m对数中至少有一个数字等于x或者y。

    思路:假设第一对为(a,b),若x,y存在,则其中之一一定是a,b中的一个数,那么如果存在(c,d),使得与a,b都不相同,那么x,y中的另一个数必在c,d中,所以x,y可能是(a,c),(a,d),(b,c),(b,d),如果不存在(c,d),则x,y就是(a,b),要对m对数进行扫描,则只要满足以下五中情况任意之一即可:(a,b),(a,c),(a,d),(b,c),(b,d)。时间复杂度O(5m)。

    #include <iostream>
    #include <cstdio>
    
    using namespace std;
    
    const int maxn = 300005;
    
    pair<int, int> pa[maxn];
    int n, m;
    
    bool check(int a, int b) {
        for (int i = 0; i < m; i++) {
            if (a != pa[i].first && a != pa[i].second && b != pa[i].first && b != pa[i].second) return false;
        }
        return true;
    }
    
    int main() {
        while (cin >> n >> m) {
            if (m == 1) {
                cin >> pa[0].first >> pa[0].second;
                cout << "YES" << endl;
                continue;
            }
            cin >> pa[0].first >> pa[0].second;
            int a = pa[0].first, b = pa[0].second, c, d;
            for (int i = 1; i < m; i++) {
                scanf("%d%d", &pa[i].first, &pa[i].second);
                if (a != pa[i].first && a != pa[i].second && b != pa[i].first && b != pa[i].second) {
                    c = pa[i].first;
                    d = pa[i].second;
                }
            }
            bool flag = check(a, b) || check(a, c) || check(a, d) || check(b, c) || check(b, d);
            if (flag)
                cout << "YES" << endl;
            else
                cout << "NO" << endl;
        }
        return 0;
    }
    
  • 相关阅读:
    对自己负责~~
    继续负责
    问题的一天
    1个月=22年
    刚才写的没显示?
    布置任务
    心情很糟
    考试结束
    没有负责哈
    php获取任意时间的时间戳
  • 原文地址:https://www.cnblogs.com/youpeng/p/10954770.html
Copyright © 2020-2023  润新知