我们来自五湖四海,不为别的,只因有共同的爱好,为中国互联网发展出一分力!
领航时时彩重庆版

时时彩万能7码技巧:HDU 1281 棋盘游戏 行列匹配

2014年07月03日17:40 阅读: 30870 次

领航时时彩重庆版 www.9nwl5.cn 题目来源:HDU 1281 棋盘游戏

题意:有一些点可以放车 放的时候不能相互攻击到 求出哪一些点必须放 不放就不能得到最大的匹配

思路:行列匹配 矩阵的每一个点对于二分图的每一条边 首先求出最大匹配ans 然后如果每次去掉一个点然后再重新求最大匹配 很耗时 可以把第一次二分匹配的图存着

然后那些关键点肯定是是匹配的边 枚举去掉那一个格点(就是去掉一条已经匹配边)如果还能匹配 那么该格点就不是关键点 关键就是不要每次重新再求最大匹配


?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
#include <cstdio>
#include <cstring>
#include <vector>
using namespace std;
const int maxn = 110;
const int maxm = 10010;
bool vis[maxn];
int y[maxn];
int n, m;
int a[maxn][maxn];
int b[maxn];
bool dfs(int u)
{
    for(int i = 0; i < m; i++)
    {
        int v = i;
        if(vis[v] || !a[u][i])
            continue;
        vis[v] = true;
        if(y[v] == -1 || dfs(y[v]))
        {
            y[v] = u;
            return true;
        }
    }
    return false;
}
int match()
{
    int ans = 0;
    memset(y, -1, sizeof(y));
    for(int i = 0; i < n; i++)
    {
        memset(vis, false, sizeof(vis));
        if(dfs(i))
            ans++;
    }
    return ans;
}
 
 
int main()
{
    int cas = 1;
    int T;
    int k;
    //scanf("%d", &T);
    while(scanf("%d %d %d", &n, &m, &k) != EOF)
    {
        memset(a, 0, sizeof(a));
        memset(b, 0, sizeof(b));
         
        while(k--)
        {
            int u, v;
            scanf("%d %d", &u, &v);
            u--;
            v--;
            a[u][v] = 1;
        }
  
           int ans = match();
           int sum = 0;
        
        for(int i = 0; i < m; i++)
        {   
            memset(b, 0, sizeof(b));
            for(int j = 0; j < m; j++)
                   if(y[j] != -1)
                       b[y[j]] = 1;
            if(y[i] == -1)
                continue;
            int temp = y[i];
            y[i] = -1;
            a[temp][i] = 0;
            b[temp] = 0;
            int flag = 0;
            for(int j = 0; j < n; j++)
            {
                memset(vis, 0, sizeof(vis));
                if(!b[j] && dfs(j))
                    flag = 1;
                if(flag)
                    break;
            }
            if(!flag)
            {
                sum++;
                y[i] = temp;
            }
            a[temp][i] = 1;
        }
            
        printf("Board %d have %d important blanks for %d chessmen.\n", cas++, sum, ans);
    }
    return 0;
}</vector></cstring></cstdio>

分享到: 更多
©2018 安全焦点 版权所有.

  • 奚国华委员:新兴际华将党建六大优势转化为发展优势 2018-12-06
  • 创业女青年哈丽娟:世界是自己的 与他人没关系 2018-12-06
  • 移植2胚怀5胎 一针减3化风险 十堰市人民医院再创生命奇迹 2018-11-06
  • 首届妈祖信俗“立德”论坛成功举办 2018-10-25
  • 郧西男孩两条腿“长”在一起 十堰市人民医院手术整形帮他迈开双腿 2018-10-25
  • 重磅 江西省委副书记李炳军同志任省委党校校长 2018-10-19
  • 商务部新闻发言人对美白宫6月18日声明发表谈话 2018-10-12
  • 从献血条件,看看你的身体是否达标 2018-09-26
  • 全国“非遗”保护工作先进名单公布 2018-09-26
  • 储大同 中国医学科学院肿瘤医院首席科学家 2018-08-15
  • 【理上网来·喜迎十九大】扶贫也创新!十八大以来年均减贫人数超1300万 获历史突破 2018-08-15
  • 开创美丽中国建设新局面 2018-08-13
  • 毛泽东三游故宫看了些什么 2018-08-13
  • 独家视频:新时代来啦! 2018-08-12
  • 旅游市场再创佳绩端午假期河北接待游客2026.77万 揽金147.79亿 2018-08-12
  • 961| 518| 126| 165| 955| 90| 671| 724| 325| 182|