Time Limit: 1000ms      Memory Limit: 128MB

Description

最小点覆盖是指在二分图中,用最小的点集覆盖所有的边。当然,一个二分图的最小点覆盖可能有很多种。

现在给定一个二分图,请你把图中的点分成三个集合:

如果在任何一种最小点覆盖中都不包含这个点,则认为该点属于N集合。

如果在任何一种最小点覆盖中都包含这个点,则认为该点属于A集合。

如果一个点既不属于N集合,又不属于A集合,则认为该点属于E集合。

Input

第一行包含三个整数n, m, k,分别表示二分图A侧点的数量,二分图B侧点的数量,边的数量。

接下来k行,每行两个整数i, j,分别表示二分图A侧第i号点与二分图B侧第j号点有连边。

数据保证无重边。

Output

第一行输出一个长度为n的字符串,其中第i个字符表示二分图A侧第i个点所属的集合。

第二行输出一个长度为m的字符串,其中第i个字符表示二分图B侧第i个点所属的集合。

Sample Input

11 9 22

1 1

1 2

1 3

1 8

1 9

2 1

2 3

3 2

3 4

4 3

4 5

5 2

5 4

5 6

6 6

6 7

7 5

7 7

8 7

9 7

10 7

11 7

Sample Output

AEEEEEENNNN

EEEEEEANN

HINT

对于10%的数据,$1≤n,m≤5$

对于40%的数据,$1≤n,m≤100$

对于100%的数据,$1≤n,m≤1000, 0≤k≤n∗m$

[吐槽]

  场上?嗯。。大眼瞪小眼qwq

[题解]

  嗯首先码一下最小点覆盖的相关知识

  König定理

  一个二分图中最大的匹配数=该图中最小点覆盖数

  (写得比较长所以就拎出来啦不然对不起自己就是这样哈哈)

  http://www.cnblogs.com/yoyoball/p/7632871.html

  从链接回到这道题

  铺垫什么的。。好像略微有点多不过。。

  嗯不管了

  然后我们就可以得出一个结论:

  如果一个点没有任何一条匹配边连到,那么这个点肯定不在最小点覆盖中

  从而与它相连的点必定要在最小点覆盖中(不然这两点之间的连边就不能覆盖到了)

  而对于一个必定在最小点覆盖中的点,与它的匹配点必定不在最小点覆盖中

  然后就这样顺着遍历同时标记就好啦

  对于那些没有被标记到的点,肯定就是属于E的啦

  好的于是在漫长的铺垫之后这题终于解决啦ovo

  (果然把最小点覆盖的东西拎出来之后清爽了很多哈哈哈)

[一些细节]

  首先。。要用long long

  其次。。注意边数

 #include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
const int MAXN=*;
struct xxx
{
int y,next;
}a[**];
char mark[MAXN];
bool vis[MAXN];
int h[MAXN],match[MAXN];
int n,m,tot,k,ans;
int add(int x,int y);
bool dfs(int x);
int solve();
int work(int x,int op); int main()
{
// freopen("a.in","r",stdin); int x,y;
scanf("%d%d%d",&n,&m,&k);
memset(h,-,sizeof(h));
tot=;
for (int i=;i<=k;++i)
{
scanf("%d%d",&x,&y);
add(x,n+y); add(n+y,x);
}
memset(match,,sizeof(match));
for (int i=;i<=n+m;++i) mark[i]='E';
for (int i=;i<=n;++i)
if (!match[i])
{
memset(vis,false,sizeof(vis));
if (dfs(i)) ++ans;
}
// for (int i=1;i<=n;++i) printf("%d ",match[i]-n);
solve();
for (int i=;i<=n;++i) printf("%c",mark[i]);
printf("\n");
for (int i=n+;i<=n+m;++i) printf("%c",mark[i]);
} int add(int x,int y)
{
a[++tot].y=y; a[tot].next=h[x]; h[x]=tot;
} bool dfs(int x)
{
int u;
for (int i=h[x];i!=-;i=a[i].next)
{
u=a[i].y;
if (vis[u]) continue;
vis[u]=true;
if (!match[u]||dfs(match[u]))
{
match[x]=u;
match[u]=x;
return true;
}
}
return false;
} int solve()
{
for (int i=;i<=n+m;++i)
{
if (!match[i])
mark[i]='N',work(i,);
}
} int work(int x,int op)
{
int u;
if (op==)
{
mark[x]='A';
work(match[x],);
return ;
}
mark[x]='N';
for (int i=h[x];i!=-;i=a[i].next)
{
u=a[i].y;
if (mark[u]=='E') work(u,);
}
}

挫挫滴代码

【noip模拟】最小点覆盖的更多相关文章

  1. NOIP模拟赛20161022

    NOIP模拟赛2016-10-22 题目名 东风谷早苗 西行寺幽幽子 琪露诺 上白泽慧音 源文件 robot.cpp/c/pas spring.cpp/c/pas iceroad.cpp/c/pas ...

  2. nyoj 237 游戏高手的烦恼 二分匹配--最小点覆盖

    题目链接:http://acm.nyist.net/JudgeOnline/problem.php?pid=237 二分匹配--最小点覆盖模板题 Tips:用邻接矩阵超时,用数组模拟邻接表WA,暂时只 ...

  3. NOIP模拟赛 by hzwer

    2015年10月04日NOIP模拟赛 by hzwer    (这是小奇=> 小奇挖矿2(mining) [题目背景] 小奇飞船的钻头开启了无限耐久+精准采集模式!这次它要将原矿运到泛光之源的矿 ...

  4. 大家AK杯 灰天飞雁NOIP模拟赛题解/数据/标程

    数据 http://files.cnblogs.com/htfy/data.zip 简要题解 桌球碰撞 纯模拟,注意一开始就在袋口和v=0的情况.v和坐标可以是小数.为保险起见最好用extended/ ...

  5. 队爷的Au Plan CH Round #59 - OrzCC杯NOIP模拟赛day1

    题目:http://ch.ezoj.tk/contest/CH%20Round%20%2359%20-%20OrzCC杯NOIP模拟赛day1/队爷的Au%20Plan 题解:看了题之后觉得肯定是DP ...

  6. CH Round #48 - Streaming #3 (NOIP模拟赛Day1)

    A.数三角形 题目:http://www.contesthunter.org/contest/CH%20Round%20%2348%20-%20Streaming%20%233%20(NOIP模拟赛D ...

  7. 2018.9.22 NOIP模拟赛

    *注意:这套题目应版权方要求,不得公示题面. 从这里开始 Problem A 妹子 Problem B 旅程 Problem C 老大 因为业务水平下滑太严重,去和高一考NOIP模拟,sad... P ...

  8. 10.17 NOIP模拟赛

    目录 2018.10.17 NOIP模拟赛 A 咒语curse B 神光light(二分 DP) C 迷宫maze(次短路) 考试代码 B 2018.10.17 NOIP模拟赛 时间:1h15min( ...

  9. NOIP模拟赛-2018.11.7

    NOIP模拟赛 如果用命令行编译程序可以发现没加头文件之类的错误. 如果用命令行编译程序可以发现没加头文件之类的错误. 如果用命令行编译程序可以发现没加头文件之类的错误. 编译之前另存一份,听说如果敲 ...

随机推荐

  1. mybatis like条件添加%的方法

    使用 MySQL可以使用CONCAT函数.例: <if test="userName != null and userName != ''"> and user_nam ...

  2. centos安装软件依赖问题

    yum install gcc gcc-c++ ncurses-devel perl 基础包安装

  3. SpringMvc出现Jsp页面不能正常解析成html网页

    <!-- Spring mvc配置 --> <servlet> <servlet-name>springMvc</servlet-name> <s ...

  4. Caused by: java.lang.ClassCastException: org.springframework.web.SpringServletContainerInitializer cannot be cast to javax.servlet.ServletContainerInitializer错误解决办法

    严重: Failed to initialize end point associated with ProtocolHandler ["http-bio-8080"] java. ...

  5. (转载,但不知道谁原创)获取SPRING 代理对象的真实实例,可以反射私有方法,便于测试

    /** * 获取 目标对象 * @param proxy 代理对象 * @return * @throws Exception */ public static Object getTarget(Ob ...

  6. python爬虫框架scrapy问题的解决

    2016-09-24:今天的弄了一天的scrapy的环境的配置的,linux很多的学过的事情都忘记啦.理论和实践的结合还是非常的重要的,不光要学会思考,更要学会总结纪录.还要多多回忆的和复习.学习了不 ...

  7. xpadder教程:自定义设置游戏手柄的图片

    关于xpadder设置按键的教程,网上已经很多,我就不凑这个热闹了.这里介绍的是如何自定义设置手柄的图片,就是按钮的背景图,如下图所示: 步骤: 1)准备一张背景图 注意:格式必须是24位色的BMP位 ...

  8. NewLife.XCode 上手指南2018版(二)增

    目录 NewLife.XCode 上手指南2018版(一)代码生成 NewLife.XCode 上手指南2018版(二)增 NewLife.XCode 上手指南2018版(三)查 NewLife.XC ...

  9. VNCServer,SSH Secure Shell Client,window远程控制linux

    1.VNC远程连接linux图形化桌面 2.SSH Secure Shell Client连接linux终端 3.设置FTP与linux传输文件 1.VNC远程连接linux图形化桌面 在centos ...

  10. Debug格式化输出----基于C语言

    Debug格式化输出----基于C语言 1. 使用宏实现 举例: #include <stdio.h> #define ECHO_COLOR_NONE "\033[0;0m&qu ...