이동 프로그램

기술

이동 같은 약간은 자기가 원하는 일이 변덕 바둑을 설계 할 수 있지만, 기본적인 질문은 : 선분으로 둘러싸인 면적을 계산하는 방법을 폐쇄?

다음의 예에서, 영역의 "0"으로 둘러싸인 "1"에 의해 기판에 5 * 5 「01」의 구성이며, 3.

0 0 0 0 0
0 1 1 1 1
0 1 0 1 0
1 0 0 1 1
1 1 1 1 0

조항 : 교차점의 수평 및 수직 라인의 수에 폐곡선에 의해 둘러싸인 영역 통계적 계산 "1"로, 특히 0 에지에서 계산되지 않는다 "0"의 다섯 번째 행이 아니기 때문에 계산 영역입니다.

입력

기판 10 × 10 행렬, 0,1 이루어지는 기판의 각 지점.

산출

1 0 밀폐 표제 영역으로부터 출력하기위한 것이다.

샘플 입력

0 0 0 0 0 0 0 0 0 1 
0 0 0 0 0 0 0 0 0 1 
0 0 0 1 1 1 0 0 0 0 
0 0 0 1 0 0 1 1 1 0 
0 0 0 0 1 1 0 0 0 1 
0 0 0 0 0 1 0 0 1 0 
0 0 0 1 1 0 0 1 0 0 
0 0 0 1 0 0 0 1 0 0 
0 0 0 0 1 1 1 0 0 0 
0 0 0 0 1 1 1 0 0 0

샘플 출력

(12)
 1 #include<iostream>
 2 //#include<fstream>
 3 using namespace std;
 4 int a[100][100];
 5 int dir[4][2]={1,0,0,-1,-1,0,0,1};
 6 void dfs(int x,int y){
 7     a[x][y]=1;
 8     int dx,dy;
 9     for(int i=0;i<4;i++){
10         dx=x+dir[i][0];
11         dy=y+dir[i][1];
12         if(dx>=1&&dx<=10&&dy>=1&&dy<=10&&!a[dx][dy])
13             dfs(dx,dy);
14     }
15 }
16 int main(){
17     int ans=0;
18     //fstream file("haha.txt");
19     for(int i=1;i<=10;i++){
20         for(int j=1;j<=10;j++){
21             //file>>a[i][j];
22             cin>>a[i][j];
23         }
24     }
25     for(int i=1;i<=10;i++){
26         if(!a[1][i])    dfs(1,i);
27         if(!a[10][i])    dfs(10,i);
28         if(!a[i][1])    dfs(i,1);
29         if(!a[i][10])    dfs(i,10);
30     }
31     for(int i=1;i<=10;i++){
32         for(int j=1;j<=10;j++){
33             if(!a[i][j])
34                 ans++;
35         }
36     }
37     cout<<ans<<endl;
38     return 0;
39 }
View Code

 

首先说方法,我们要把圈外的0都变成1,然后遍历整个数组数一数一共有几个0那么围成的面积就是几

然后说一下怎么实现,主体思想是用dfs或者bfs,因为我们只想把圈外的0变成1,所以我们从边缘开始搜索

    for(int i=1;i<=10;i++){
        if(!a[1][i])    dfs(1,i);
        if(!a[10][i])    dfs(10,i);
        if(!a[i][1])    dfs(i,1);
        if(!a[i][10])    dfs(i,10);
    }

这个代码实现的就是这一块,注意必须要从边缘开始,不能遍历整个数组搜索,如果遍历整个数组搜索的话,数组里所有的0都会变成1了。

然后就是dfs的思想,上下左右连一块的算连着,斜着的不算,从边缘开始,所有连着的0变成1。





추천

출처www.cnblogs.com/fate-/p/12233487.html