πŸ“– [λ°±μ€€μ•Œκ³ λ¦¬μ¦˜ 풀이] Q.1780 μ’…μ΄μ˜ 개수 문제 풀이 - java

πŸ“– 문제

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

NΓ—N크기의 ν–‰λ ¬λ‘œ ν‘œν˜„λ˜λŠ” 쒅이가 μžˆλ‹€. μ’…μ΄μ˜ 각 μΉΈμ—λŠ” -1, 0, 1의 μ„Έ κ°’ 쀑 ν•˜λ‚˜κ°€ μ €μž₯λ˜μ–΄ μžˆλ‹€. μš°λ¦¬λŠ” 이 행렬을 μ μ ˆν•œ 크기둜 자λ₯΄λ €κ³  ν•˜λŠ”λ°, μ΄λ•Œ λ‹€μŒμ˜ κ·œμΉ™μ— 따라 자λ₯΄λ €κ³  ν•œλ‹€.

λ§Œμ•½ 쒅이가 λͺ¨λ‘ 같은 수둜 λ˜μ–΄ μžˆλ‹€λ©΄ 이 쒅이λ₯Ό κ·ΈλŒ€λ‘œ μ‚¬μš©ν•œλ‹€. (1)이 μ•„λ‹Œ κ²½μš°μ—λŠ” 쒅이λ₯Ό 같은 크기의 9개의 μ’…μ΄λ‘œ 자λ₯΄κ³ , 각각의 잘린 쒅이에 λŒ€ν•΄μ„œ (1)의 과정을 λ°˜λ³΅ν•œλ‹€. 이와 같이 쒅이λ₯Ό μž˜λžμ„ λ•Œ, -1둜만 μ±„μ›Œμ§„ μ’…μ΄μ˜ 개수, 0으둜만 μ±„μ›Œμ§„ μ’…μ΄μ˜ 개수, 1둜만 μ±„μ›Œμ§„ μ’…μ΄μ˜ 개수λ₯Ό κ΅¬ν•΄λ‚΄λŠ” ν”„λ‘œκ·Έλž¨μ„ μž‘μ„±ν•˜μ‹œμ˜€.

πŸ” 접근법

Q.1780 μ’…μ΄μ˜ 개수 λ¬Έμ œμž…λ‹ˆλ‹€.

Q.1992 μΏΌλ“œνŠΈλ¦¬ λ¬Έμ œμ™€ λΉ„μŠ·ν•œ λ¬Έμ œμž…λ‹ˆλ‹€.

λ¬Έμ œμ— 주어진 쑰건을 잘 μ‚΄νŽ΄λ³΄λ©΄ μ‰½κ²Œ 풀이가 κ°€λŠ₯ν•©λ‹ˆλ‹€.

N * N 크기의 쒅이 행렬이 μ£Όμ–΄μ§‘λ‹ˆλ‹€. 이 μ’…μ΄μ˜ 각 μΉΈμ—λŠ” -1 , 0 , 1의 μ„Έ κ°’ 쀑 ν•˜λ‚˜κ°€ μ €μž₯λ˜μ–΄ μžˆλŠ”λ°

이 쒅이듀을 μ μ ˆν•œ 크기둜 자λ₯΄λ €κ³  ν•©λ‹ˆλ‹€.

이 λ•Œ 쒅이가 λͺ¨λ‘ 같은 μˆ˜κ°€ λ˜μ–΄μžˆμ„λ•Œ 이 쒅이λ₯Ό κ·ΈλŒ€λ‘œ μ‚¬μš©ν•˜λ €κ³  ν•©λ‹ˆλ‹€.

쒅이가 λͺ¨λ‘ 같은 μˆ˜κ°€ μ•„λ‹ˆλΌλ©΄ 같은 크기둜 9개의 쒅이λ₯Ό 자λ₯΄κ³  λ‹€μ‹œ 같은 수둜 μ΄λ£¨μ–΄μ ΈμžˆλŠ”μ§€λ₯Ό

ν™•μΈν•˜κΈ°λ₯Ό λ°˜λ³΅ν•˜λ©΄ λ©λ‹ˆλ‹€.

λ˜‘κ°™μ€ 크기둜 계속 λΆ„ν• ν•˜λ©° ν™•μΈν•˜λ―€λ‘œ

뢄할정볡 μ•Œκ³ λ¦¬μ¦˜μ„ 톡해 풀이가 κ°€λŠ₯ν•©λ‹ˆλ‹€.

문제 κ·ΈλŒ€λ‘œ 쒅이가 같은 μˆ˜κ°€ μ•„λ‹ˆλΌλ©΄ 9λ“±λΆ„μœΌλ‘œ λ‚˜λˆ„κ³  쒅이가 같은 μˆ˜μΈμ§€ μ•„λ‹Œμ§€ ν™•μΈν•˜λŠ” 과정을 λ°˜λ³΅ν•˜λ©΄

닡을 λ„μΆœν•΄λ‚Ό 수 μžˆμŠ΅λ‹ˆλ‹€.

이 과정을 λ°˜λ³΅ν•˜λ©° λͺ¨λ“  μˆ«μžκ°€ 0인 경우, 1인 경우 , -1인 경우λ₯Ό λͺ¨λ‘ κ΅¬ν•˜λ©΄ λ©λ‹ˆλ‹€.

πŸ’» μ½”λ“œ

package problem.divide_conquer;

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

public class Main_1780 {
    static int n;
    static int paper[][];
    static int minusOne = 0;
    static int zero = 0;
    static int plusOne = 0;

    public static void main(String[] args) throws IOException {
        input();
        solve(0, 0, n);
        System.out.println(minusOne);
        System.out.println(zero);
        System.out.println(plusOne);
    }

    private static void input() throws IOException {
        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
        n = Integer.parseInt(br.readLine());
        paper = new int[n][n];
        for (int i = 0; i < n; i++) {
            String[] input = br.readLine().split(" ");
            for (int j = 0; j < n; j++) {
                paper[i][j] = Integer.parseInt(input[j]);
            }
        }

        br.close();
    }

    private static void solve(int startX, int startY, int len) {
        if (check(startX, startY, len)) {
            if (paper[startY][startX] == 1) {
                plusOne++;
            } else if (paper[startY][startX] == 0) {
                zero++;
            } else {
                minusOne++;
            }
        } else {

            int length = len / 3;
            solve(startX, startY, length);
            solve(startX, startY + length, length);
            solve(startX, startY + (2 * length), length);

            solve(startX + length, startY, length);
            solve(startX + length, startY + length, length);
            solve(startX + length, startY + (2 * length), length);

            solve(startX + (2 * length), startY, length);
            solve(startX + (2 * length), startY + length, length);
            solve(startX + (2 * length), startY + (2 * length), length);
        }
    }

    public static boolean check(int startX, int startY, int len) {
        int number = paper[startY][startX];
        for (int i = startY; i < startY + len; i++) {
            for (int j = startX; j < startX + len; j++) {

                if (number != paper[i][j]) {
                    return false;
                }
            }
        }
        return true;
    }
}
Written on May 3, 2021