Saturday, May 26, 2012

UVA 11094 Continents Solution

 
 
 
Mijid the Great is the king of Dodars territory. He likes to travel between the cities in his territory and actually, you can never see him in the same city as where he was the day before. Therefore, he captured all territories of his continent! In spite of this fact, he has seen all cities of his territory so far and wants to capture another continent in order to have some choices to travel into new cities. Now, having the world map, he needs your help to find the biggest continent except the one in which he resides.
Maps are given as M x N tables, filled with at most two different letters denoting land and water regions. A continent is a set of connected land regions which is completely surrounded by water regions or the end of map. Two regions are assumed to be connected if they have an edge in common. The coordinates of top left region is (0,0) and bottom right region (M-1,N-1). Region with coordinates (x,N-1) should be assumed to  have a common edge with region (x,0) for every x between 0 and M-1 (inclusive).

Input

There will be several test cases. Each test case contains two integers M<=20 and N<=20 in the first line denoting the number of rows and columns in the map respectively. Next, there will be M lines of exactly Ncharacters representing the map. Finally in the last line there would be two integers 0<=X<M and 0<=Y<N , the coordinates of the region in which Mijid the Great currently stays. There will one blank line after each test case.

Output

For each test case, output a line containing an integer that is the number of regions in the biggest continent that Mijid the Great can capture.

Sample Input                               Output for Sample Input

5 5
wwwww
wwllw
wwwww
wllww
wwwww
1 3
 
2
Solution :
 
 
 
#include <cstdio>
#include <iostream>

using namespace std;
#define sz 32

char grid[sz][sz];
bool used[sz][sz];
int R,C,I,J,ans,land;


int dfs(int i,int j){
 if(i < 0 || i >= R)
  return 0;
 if(j == -1)
  j = C-1;
 else if(j == C)
  j = 0;
 
 if(grid[i][j] != land)
  return 0;

 grid[i][j] = 0;

 return 1 + dfs(i-1,j) + dfs(i+1,j) + dfs(i,j-1) + dfs(i,j+1);
}
int calc(){
 int cnt;
 ans = 0;
 land = grid[I][J];
 dfs(I,J);
 for(int i = 0; i < R; i++){
  for(int j = 0; j < C; j++){
   if(grid[i][j] == land){
    cnt = dfs(i,j);
    if(cnt > ans)
     ans = cnt;
   }
  }
 }
 return ans;
}

int main(){
 //freopen("i.txt","r",stdin);

 while(scanf("%d %d",&R,&C) == 2){
  for(int i = 0; i < R; i++){
   scanf("%s",grid[i]);
  }
  scanf("%d %d",&I,&J);
  printf("%d\n",calc());
 }
 return 0;
}

No comments:

Post a Comment