Algorithm/백준 문제풀이

[백준] 1743 음식물 피하기 - Java

너지살 2023. 10. 18. 15:59

 

 

문제 출저

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

 

1743번: 음식물 피하기

첫째 줄에 통로의 세로 길이 N(1 ≤ N ≤ 100)과 가로 길이 M(1 ≤ M ≤ 100) 그리고 음식물 쓰레기의 개수 K(1 ≤ K ≤ N×M)이 주어진다.  그리고 다음 K개의 줄에 음식물이 떨어진 좌표 (r, c)가 주어진다

www.acmicpc.net

 

 

 

문제 풀이

음식물 쓰레기 위치가 주어졌을 때, 가장 큰 덩어리의 크기를 구하는게 문제입니다. 

 

저는 BFS를 통해서 풀었습니다. 

2차원 배열을 하나씩 탐색하면 음식물 쓰레기면 BFS를 통해서 덩어리를 구했습니다.

이를 통해 가장 큰 덩어리를 구했습니다. 

 

 

 

소스 코드 

package baekjoon.backjoon10.day1120.day18;

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


/*
https://www.acmicpc.net/problem/1743
음식물 피하기
 */

public class B1743 {

    static int n, m, k;
    static boolean[][] board;
    static boolean[][] visited;
    static int[] dx = {1,0,-1,0};
    static int[] dy = {0,-1,0,1};
    static int answer;

    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());
        k = Integer.parseInt(st.nextToken());
        board = new boolean[n][m];
        for(int i = 0; i < k; i++) {
            st = new StringTokenizer(br.readLine());
            int y = Integer.parseInt(st.nextToken()) - 1;
            int x = Integer.parseInt(st.nextToken()) - 1;

            board[y][x] = true;
        }

        visited = new boolean[n][m];
        answer = 0;

        for(int i = 0; i < n; i++) {
            for(int j = 0; j < m; j++) {
                if(board[i][j] && visited[i][j] == false) {
                    search(i, j);
                }
            }
        }

        System.out.println(answer);


    }

    public static void search(int y, int x) {


        visited[y][x] = true;
        int result = 1;

        Queue<dot> que = new LinkedList<>();
        que.add(new dot(y,x));

        while (!que.isEmpty()) {
            dot d = que.poll();

            for(int i = 0; i < 4; i++) {
                int ny = d.y + dy[i];
                int nx = d.x + dx[i];

                if(check(ny,nx)) {
                    que.add(new dot(ny,nx));
                    visited[ny][nx] = true;
                    result++;
                }

            }

        }

        answer = Math.max(answer, result);

    }

    public static boolean check(int y, int x) {
        if(y >= 0 && y < n && x >= 0 && x < m && board[y][x] == true && visited[y][x] == false){
            return true;
        }
        else {
            return false;
        }
    }

    public static class dot {
        int y;
        int x;

        dot(int y, int x) {
            this.y = y;
            this.x = x;
        }
    }

}