BZOJ3175 Tjoi2013 攻擊裝置(二分圖匹配)

傳送門

Description

給定一個01矩陣,其中你可以在0的位置放置攻擊裝置。每一個攻擊裝置(x,y)都可以按照“日”字攻擊其周圍的 8個位置(x-1,y-2),(x-2,y-1),(x+1,y-2),(x+2,y-1),(x-1,y+2),(x-2,y+1), (x+1,y+2),(x+2,y+1)
求在裝置互不攻擊的情況下,最多可以放置多少個裝置。

Input

第一行一個整數N,表示矩陣大小爲N*N。接下來N行每一行一個長度N的01串,表示矩陣。

Output

一個整數,表示在裝置互不攻擊的情況下最多可以放置多少個裝置。

Sample Input

3
010
000
100

Sample Output

4

HINT

100%數據 N<=200

這……這不是裸的二分圖最大點獨立集麼……匈牙利水過……

/**************************************************************
    Problem: 3175
    User: geng4512
    Language: C++
    Result: Accepted
    Time:840 ms
    Memory:9240 kb
****************************************************************/

#include<cstdio>
#define MAXN 40005
#define MAXM 1000005
struct node { int v, nxt; }e[MAXM];
int n, ecnt, Adj[MAXN], cnt, dd[8][2] = {-1, -2, -1, 2, -2, -1, -2, 1, 1, 2, 1, -2, 2, 1, 2, -1}, c[MAXN], tag, vis[MAXN];
inline void Add(int u, int v) {
    ++ ecnt; e[ecnt].v = v; e[ecnt].nxt = Adj[u]; Adj[u] = ecnt;
}
char s[300][300];
int dfs(int u) {
    vis[u] = tag;
    for(int i = Adj[u]; i; i = e[i].nxt) 
        if(tag != vis[e[i].v]) {
            vis[e[i].v] = tag;
            if(!c[e[i].v] || dfs(c[e[i].v])) {
                c[u] = e[i].v;
                c[e[i].v] = u;
                return 1;
            }
        }
    return 0;
}
inline int Hungary() {
    int ans = 0;
    for(int i = 1; i < n*n; ++ i) tag = i, ans += dfs(i);
    return ans;
}
int main() {
    scanf("%d", &n);
    for(int i = 0; i < n; ++ i)
        scanf("%s", s[i]);
    for(int i = 0; i < n; ++ i) {
        for(int j = 0; j < n; ++ j) {
            if(s[i][j]-'0') ++ cnt;
            else if((i+j)&1){
                for(int k = 0; k < 8; ++ k) {
                    int x = i + dd[k][0], y = j + dd[k][1];
                    if(x < 0 || x >= n || y < 0 || y >= n || s[x][y] == '1') continue;
                    Add(i*n+j, x*n+y);
                }
            }
        }
    }
    int ans = n*n-Hungary()-cnt;
    printf("%d\n", ans);
    return 0;
}

發佈了116 篇原創文章 · 獲贊 24 · 訪問量 12萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章