BZOJ2079[Poi2010] Guilds

30 篇文章 0 订阅
23 篇文章 1 订阅

BZOJ2079[Poi2010] Guilds

Description

Zy皇帝面临一个严峻的问题,两个互相抵触的贸易团体,YYD工会和FSR工会,他们在同一时间请求在王国各个城市开办自己的办事处。这里有n个城市,其中有一些以双向马路相连,这两个工会要求每个城市应该做到: 1:有这个工会的办事处或 2:和另外一个符合1条件的城市有马路直接相连。(也就是每个城市必须是YYD的公会,但是又和FSR的公会的城市相连,或者是FSR的,和YYD的城市相连,或者和两个工会的城市相连)但是Zy怀疑不正当的竞争,他担心一个城市有两个工会的办事处,(就是说一个城市不能有两个工会的办事处)只将导致贸易的垄断(政治怎么学的),所以他请求他日夜栽培的你给予帮助。

Input

输入:两个整数n(1<=n<=200000)和m(1<=m<=500000),n代表城市数,m代表道路的总数,接下来m行每行两个整数ai和bi,表示城市ai和城市bi有道路相接。不会有重边。

Output

输出:如果这些公会的办事处能够不违反规则的开办则第一行输出TAK(波兰语的Yes),如果这些工会的办事处无法按照规则开办,就输出NIE(波兰语的No)。

Sample Input

7 8

1 2

3 4

5 4

6 4

7 4

5 6

5 7

6 7

Sample Output

TAK

题目描述

YYD的城市是圆圈,FSR的城市是菱形.

Solution:

真-玄学…

对于答案来说的话,其实很简单:如果存在一个孤立的点,那么答案就是NIE,否则就是TAK。

也就是说任意联通块都能满足这个约束。

我的考虑是这样的:这道题显然连边多比连边少要更容易满足。因此我们对这个图进行减边,直到变成一棵树。一颗树是显然可以的,只要分层染色即可。然后把边添回去的过程中并不会引起矛盾,于是就证完了。

#include<stdio.h>
#define M 200005
bool mark[M];
int main(){
    int n,m,a,b;
    scanf("%d %d",&n,&m);
    for(int i=1;i<=m;i++){
        scanf("%d %d",&a,&b);
        mark[a]=mark[b]=true;
    }
    for(int i=1;i<=n;i++)
        if(!mark[i]){
            puts("NIE");
            return 0;
        }
    puts("TAK");
    return 0;
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值