CF1248F Catowice市

トピックリンク

問題

そこ\(N \)個人が、それぞれの家族は猫を持っています。誰もが(確かに、自分の猫を含む)に、いくつかの猫を知っていました。選択し\(J \)個人と\(k個\)\((J、K \ GE 1)\) このようなこと\(J + K = N \ ) や猫、お互いを知りませ選出。

解決

明白だが重要な帰結は、次のとおりです。

それぞれの人は、人や猫に行かなければなりません。

私達はちょうどあなたがそれらの間の関係は、他の人や猫の人々で起動することができ、家に行くために最初の人は、人や猫である列挙する必要があります。問題の最初の選択肢の人々はまだ猫を選択すると、につながる\(N \)猫や\(N \)なし解個人。

コード

#include<cstdio>
#include<queue>
#include<vector>
#include<algorithm>
#include<iostream>
#include<cstring>
#include<ctime>
using namespace std;
typedef long long ll;
const int N = 1000100;
ll read() {
    ll x = 0,f = 1;char c = getchar();
    while(c < '0' || c > '9') {
        if(c == '-') f = -1;c = getchar();
    }
    while(c >= '0' && c <= '9') {
        x = x * 10 + c - '0';
        c = getchar();
    }
    return x * f;
}
vector<int>e1[N],e2[N];
int vis[N],cnt;
void dfs(int u) {
    vis[u] = 1;cnt++;
    for(vector<int>::iterator it = e1[u].begin();it != e1[u].end();++it) {
        if(vis[*it]) continue;
        dfs(*it);
    }
}
void dfs2(int u) {
    vis[u] = 1;cnt++;
    for(vector<int>::iterator it = e2[u].begin();it != e2[u].end();++it) {
        if(vis[*it]) continue;
        dfs2(*it);
    }
}
int main() {
    int T = read();
    while(T--) {
        int n = read(),m = read();
        cnt = 0;
        for(int i = 1;i <= n;++i) vis[i] = 0;
        for(int i = 1;i <= n;++i) e1[i].clear(),e2[i].clear();
        for(int i = 1;i <= m;++i) {
            int u = read(),v = read();
            e1[u].push_back(v);e2[v].push_back(u);
        }
        dfs(1);
        int bz = 1;
        if(cnt == n) {
            cnt = 0;
            for(int i = 1;i <= n;++i) vis[i] = 0;
            dfs2(1);
            if(cnt == n) {puts("No");continue;}
            cnt = n - cnt;
            bz = 0;
        }
        puts("Yes");
        printf("%d %d\n",cnt,n - cnt);
        for(int i = 1;i <= n;++i) {
            if(vis[i] == bz) printf("%d ",i);
        }
        puts("");
        for(int i = 1;i <= n;++i) {
            if(vis[i] != bz) printf("%d ",i);
        }
        puts("");
    }
    return 0;
}

おすすめ

転載: www.cnblogs.com/wxyww/p/CF1248F.html