• 【2017"百度之星"程序设计大赛


    【链接】http://bestcoder.hdu.edu.cn/contests/contest_showproblem.php?cid=775&pid=1006


    【题意】


    在这里写题意

    【题解】


    先找出最外围的0,把那些0都去掉.
    从(0,0)开始广搜,这样就能把整个外围都去掉了;
    (注意要把这些0去掉)
    (图是存在(1,1)~(n,m)里面的)
    然后找(1,1)~(n,m)里面的1的联通块个数.
    再找0的联通块个数.(在去掉外围的0之后)
    (这个时候0只能是1联通块里面的联通块了.或者干脆就找不到了)
    然后看看1的联通块个数是不是1,是1的话,看0的联通块个数;
    个数为0的话,就是0,否则是1.

    【错的次数】


    0

    【反思】


    在这了写反思

    【代码】

    #include <bits/stdc++.h>
    using namespace std;
    #define lson l,m,rt<<1
    #define rson m+1,r,rt<<1|1
    #define LL long long
    #define rep1(i,a,b) for (int i = a;i <= b;i++)
    #define rep2(i,a,b) for (int i = a;i >= b;i--)
    #define mp make_pair
    #define pb push_back
    #define fi first
    #define se second
    #define ms(x,y) memset(x,y,sizeof x)
    #define ri(x) scanf("%d",&x)
    #define rl(x) scanf("%lld",&x)
    #define rs(x) scanf("%s",x+1)
    #define oi(x) printf("%d",x)
    #define ol(x) printf("%lld",x)
    #define oc putchar(' ')
    #define os(x) printf(x)
    #define all(x) x.begin(),x.end()
    #define Open() freopen("F:\rush.txt","r",stdin)
    #define Close() ios::sync_with_stdio(0)
    
    
    typedef pair<int,int> pii;
    typedef pair<LL,LL> pll;
    
    
    const int dx[9] = {0,1,-1,0,0,-1,-1,1,1};
    const int dy[9] = {0,0,0,-1,1,-1,1,-1,1};
    const double pi = acos(-1.0);
    const int N = 110;
    
    
    int n,m;
    char s[N][N];
    bool vis[N][N];
    queue <pii> dl;
    
    
    
    
    
    
    int main(){
        //Open();
        //Close();
        while (~ri(n)){
            ms(vis,0);
            ri(m);
            rep1(i,1,n) rs(s[i]);
    
    
            dl.push(mp(0,0));
            while (!dl.empty()){
                int x = dl.front().first,y = dl.front().second;
                dl.pop();
                rep1(i,1,4){
                    int tx = x + dx[i],ty = y + dy[i];
                    if (tx >= 0 && tx <= n+1 && ty >= 0 && ty <= m+1){
                        if (!vis[tx][ty]){
                            if (tx >=1 && tx <= n && ty >= 1 && ty <= m)
                                if (s[tx][ty]=='1') continue;
                            vis[tx][ty] = 1;
                            dl.push(mp(tx,ty));
                        }
                    }
                }
            }
            //return 0;
    
    
            int nei1 = 0;
            rep1(i,1,n)
                rep1(j,1,m)
                    if (s[i][j]=='1' && !vis[i][j]){
                        nei1++;
                        vis[i][j] = 1;
                        dl.push(mp(i,j));
                        while (!dl.empty()){
                            int x = dl.front().first,y = dl.front().second;
                            dl.pop();
                            rep1(i,1,4){
                                int tx = x + dx[i],ty = y + dy[i];
                                if (tx >= 1 && tx <= n && ty >= 1 && ty <= m){
                                    if (s[tx][ty]=='1' && !vis[tx][ty]){
                                        vis[tx][ty] = 1;
                                        dl.push(mp(tx,ty));
                                    }
                                }
                            }
                        }
                    }
    
    
            if (nei1==0 || nei1 > 1){
                puts("-1");
                continue;
            }
    
    
            int nei0 = 0;
            rep1(i,1,n)
                rep1(j,1,m)
                    if (s[i][j]=='0' && !vis[i][j]){
                        nei0++;
                        vis[i][j] = 1;
                        dl.push(mp(i,j));
                        while (!dl.empty()){
                            int x = dl.front().first,y = dl.front().second;
                            dl.pop();
                            rep1(i,1,4){
                                int tx = x + dx[i],ty = y + dy[i];
                                if (tx >= 1 && tx <= n && ty >= 1 && ty <= m){
                                    if (s[tx][ty]=='0' && !vis[tx][ty]){
                                        vis[tx][ty] = 1;
                                        dl.push(mp(tx,ty));
                                    }
                                }
                            }
                        }
                    }
    
    
            if (nei1 == 1 && nei0 == 1){
                puts("0");
                continue;
            }
            if (nei1 == 1 && nei0 == 0){
                puts("1");
                continue;
            }
            puts("-1");
        }
        return 0;
    }
    


  • 相关阅读:
    Laravel 中使用支付宝、银联支付、微信支付进行支付
    C# 文件读写系列三
    C# 文件读写系列二
    C# Encoding
    C# 文件操作系列一
    Unity 依赖注入
    控制反转和依赖注入模式
    Aop学习笔记系列一
    C# lambda表达式
    C# 委托基础
  • 原文地址:https://www.cnblogs.com/AWCXV/p/7626094.html
Copyright © 2020-2023  润新知