zoukankan      html  css  js  c++  java
  • Problem J: Island Buses

    主要题意是:大海之间有岛,有的岛之间有桥,问你岛的个数,桥的个数,以及没有桥联通岛的个数,其中最后一次输入的没有回车,不注意的话最后一次会被吞,第二,桥的两端的标记是“X”(X也代表陆地),“X”的四周都可以有“B”形成的桥,一开始没写好,后来根据“X”标记所有的桥只能走一次然后标记……总之,虽然是水题,写出来还是蛮开心的……

    #include <iostream>
    #include <cstdio>
    #include <cstdlib>
    #include <algorithm>
    #include <map>
    #include <cmath>
    #include <cstring>
    #include <string>
    #include <queue>
    #include <stack>
    #include <cctype>
    
    const double Pi = atan(1) * 4;
    using namespace std;
    char str[100][100];
    bool visit1[100][100];
    bool visit2[100][100];
    int cnt ;
    int len;
    int bridge;
    int dr[] = {1,-1,0,0};
    int dc[] = {0,0,-1,1};
    void dfs1(int r,int c){
        visit1[r][c] = 1;
        for(int i = 0;i < 4;i++){
            int xx = r + dr[i];
            int yy = c + dc[i];
            if(xx >= 0 && yy >= 0 && xx < cnt && yy < len){
                if(!visit1[xx][yy] && (str[xx][yy] == '#' || str[xx][yy] == 'X' )){
                    dfs1(xx,yy);
                }
            }
        }
    }
    void dfs2(int r,int c){
        visit2[r][c] = 1;
        for(int i = 0;i < 4;i++){
            int xx = r + dr[i];
            int yy = c + dc[i];
            if(xx >= 0 && yy >= 0 && xx < cnt && yy < len){
                if(!visit2[xx][yy] && (str[xx][yy] == '#' || str[xx][yy] == 'X')){
                    dfs2(xx,yy);
                }
                else if(str[xx][yy] == 'B' && str[r][c] == 'X' && !visit2[xx][yy]){
                    int j = 0;
                    visit2[xx][yy] = 1;
                    bridge++;
                    while(1){
                        j++;
                        int tt1 = xx + j * dr[i];
                        int tt2 = yy + j *  dc[i];
                        if(tt1 < 0 || tt2 < 0 || tt1 >= cnt || tt2 >= len)
                            break;
                        visit2[tt1][tt2] = 1;
                        if(str[tt1][tt2] == 'X'){
                            dfs2(tt1,tt2);
                            break;
                        }
                    }
                }
            }
        }
    }
    int main()
    {
        //freopen("input.in","r",stdin);
        //freopen("output.in","w",stdout);
        cnt = 0;
        int cas = 1;
        memset(str,0,sizeof(str));
        while(fgets(str[0],sizeof(str[0]),stdin) != NULL){
            if(cas != 1)
                cout << endl;
            len = strlen(str[0]) - 1;
            while((fgets(str[++cnt],sizeof(str[0]),stdin) )!= NULL){
                if(str[cnt][0] == 10){
                    break;
                }
            }
            bridge = 0;
            int bus = 0;
            int island = 0;
            memset(visit1,0,sizeof(visit1));
            memset(visit2,0,sizeof(visit2));
            for(int i = 0;i <= cnt;i++){
                for(int j = 0;j < len;j++){
                    if( (str[i][j] == '#' || str[i][j] == 'X') && !visit1[i][j]){
                        island++;
                        dfs1(i,j);
                    }
                    if( (str[i][j] == '#' || str[i][j] == 'X')&& !visit2[i][j]){
                        bus++;
                        dfs2(i,j);
                    }
                }
            }
            cout << "Map " << cas++ << endl;
            cout << "islands: " << island << endl;
            cout << "bridges: " << bridge << endl;
            cout << "buses needed: " << bus << endl;
            cnt = 0;
            memset(str,0,sizeof(str));
        }
        return 0;
    }
    View Code
  • 相关阅读:
    POJ 3468_A Simple Problem with Integers(树状数组)
    POJ 3468_A Simple Problem with Integers(线段树)
    ZOJ 2770_Burn the Linked Camp
    ZOJ 2770_Burn the Linked Camp
    POJ 3169_Layout
    POJ 3169_Layout
    POJ 3684_Physics Experiment
    POJ 3255_Roadblocks
    POJ 3723 Conscription【最小生成树】
    POJ 3279 Fliptile【枚举】
  • 原文地址:https://www.cnblogs.com/hanbinggan/p/4256478.html
Copyright © 2011-2022 走看看