Java

[백준 2573] 빙산 (JAVA)

iheeeee6-6 2023. 5. 25. 13:22
728x90

https://www.acmicpc.net/problem/2573

 

2573번: 빙산

첫 줄에는 이차원 배열의 행의 개수와 열의 개수를 나타내는 두 정수 N과 M이 한 개의 빈칸을 사이에 두고 주어진다. N과 M은 3 이상 300 이하이다. 그 다음 N개의 줄에는 각 줄마다 배열의 각 행을

www.acmicpc.net

dfs를 사용해여 해결할 수 있었다.

영역을 나눌때 dfs를 사용해서 연결된 빙산을 쭉 재귀로 가고

방문 표시를 한 후, 영역의 수를 올린다.

그렇게 이중 포문을 통해 방문 하지 않은 곳을 찾아 방문 한 후 영역 갯수 return !

 

1년마다 높이를 깎는거는 간단하게 재귀를 사용하지 않고 3중 포문을 썼다.

이차원 배열을 하나 더 선언해서 해당 배열에 결과값을 넣고 return!

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.StringTokenizer;

public class Main {

	static int n, m, result = 0;
	static int[][] arr;
	static boolean[][] visited;
	static int[] dx = { 1, -1, 0, 0 };
	static int[] dy = { 0, 0, 1, -1 };

	public static void main(String[] args) throws IOException {
		BufferedReader br = new BufferedReader(new InputStreamReader(System.in));

		StringTokenizer st = new StringTokenizer(br.readLine());
		n = Integer.parseInt(st.nextToken());
		m = Integer.parseInt(st.nextToken());
		arr= new int[n][m];
		for (int i = 0; i < n; i++) {
			st = new StringTokenizer(br.readLine());
			for (int j = 0; j < m; j++) {
				arr[i][j] = Integer.parseInt(st.nextToken());
			}
		}

		int count=0;
		while ((count=check())<2) {
			if (count==0) {
				result=0;
				break;
			}

			result++;

			arr=live();

		}
		
		System.out.println(result);
	}

	static int check() {
		visited= new boolean[n][m];
		int countTemp = 0;
		for (int i = 0; i < n; i++) {
			for (int j = 0; j < m; j++) {
				if (arr[i][j] > 0&&visited[i][j]==false) {
					dfs(i,j);
					countTemp++;
				}
			}
		}

		return countTemp ;
	}

	static void dfs(int x,int y) {
		visited[x][y]=true;
		for (int z = 0; z < 4; z++) {
			int xx = x + dx[z];
			int yy = y + dy[z];
			if (xx < 0 || yy < 0 || xx > n - 1 || yy > m - 1||visited[xx][yy])
				continue;
			if (arr[xx][yy] > 0) {
				dfs(xx,yy);
			}
		}
	}
	static int[][] live() {
		int[][] arr2 = new int[n][m];
		for (int i = 0; i < n; i++) {
			for (int j = 0; j < m; j++) {
				int minus=0;
				if (arr[i][j] > 0) {
					for (int z = 0; z < 4; z++) {
						int xx = i + dx[z];
						int yy = j + dy[z];
						if (xx < 0 || yy < 0 || xx > n - 1 || yy > m - 1)
							continue;
						if (arr[xx][yy] == 0) {
							minus++;
						}
					}
				}
				arr2[i][j]=arr[i][j]-minus<=0?0:arr[i][j]-minus;
			}
		}
		
		return arr2;
	}
}