首页 > 技术文章 > 题解——面积(area.cpp)

littlefrog 2019-09-20 21:43 原文

题目来源&题面简述:

img

思路与算法选择:

只有*里面的部分对我们有用,所以可以将 *号外的部分标记一下。

可以用著名的BFS大法实现此过程。(连通块)
连通块模板:

#include<bits/stdc++.h>
using namespace std;
struct node
{
    int x;
    int y;
    node(){}
    node(int x1,int y1):x(x1),y(y1){}
 
};
int n,m;
int u[4][2]={{1,0},{-1,0},{0,1},{0,-1}};
 
int head=1;
int tail=1;
int s[105][105];
int sum=0;
void bfs(int x,int y)
{
    queue<node>Q;
    s[x][y]=0;
    Q.push(node(x,y));
    while(!Q.empty()){
        node a=Q.front();
        Q.pop();
        for(int i=0;i<4;i++){
            int xx=u[i][0]+a.x;
            int yy=u[i][1]+a.y;
            if(xx>=0&&xx<n&&yy>=0&&yy<m&&(s[xx][yy])){
                s[xx][yy]=0;
                Q.push(node(xx,yy));
            }
        }
    }
}
int main()
{
    cin>>n>>m;
    for(int i=0;i<n;i++){
        for(int j=0;j<m;j++){
            cin>>s[i][j];
        }
    }
    for(int i=0;i<n;i++){
        for(int j=0;j<m;j++){
            if(s[i][j]){
                sum++;
                bfs(i,j);
            }
        }
    }
    cout<<sum<<endl;
 
    return 0;
}

这里只需按模板改就行了。

#include<bits/stdc++.h>
using namespace std;
struct node
{
    int x;
    int y;
    node(){}
    node(int x1,int y1):x(x1),y(y1){}

};
int n,m;
int u[4][2]={{1,0},{-1,0},{0,1},{0,-1}};

int head=1;
int tail=1;
int s[105][105];
int sum=0;
void bfs(int x,int y)
{
    queue<node>Q;
    s[x][y]=-1;
    Q.push(node(x,y));
    while(!Q.empty()){
        node a=Q.front();
        Q.pop();
        for(int i=0;i<4;i++){
            int xx=u[i][0]+a.x;
            int yy=u[i][1]+a.y;
            if(xx>=0&&xx<n&&yy>=0&&yy<m&&(s[xx][yy]==0)){
                s[xx][yy]=-1;
                Q.push(node(xx,yy));
            }
        }
    }
}
int main()
{
    cin>>n>>m;
    for(int i=0;i<n;i++){
        for(int j=0;j<m;j++){
            cin>>s[i][j];
        }
    }
    for(int i=0;i<m;i++){
        bfs(0,i);
    }
    for(int j = 0;j<n;++j) {
      bfs(j,0);
    }
    for(int i=0;i<m;i++){
        bfs(n-1,i);
    }
    for(int j = 0;j<n;++j) {
      bfs(j,m-1);
    }

   int ans = 0;
    for(int i=0;i<n;i++){
        for(int j=0;j<m;j++){
            if(s[i][j]==0) {
               ans++;
            }
        }
    }
    cout<<ans<<endl;
    return 0;
}

推荐阅读