[알고리즘] Java / 백준 / 스도쿠 / 2239

정현명·2022년 4월 6일
0

baekjoon

목록 보기
121/180
post-thumbnail

[알고리즘] Java / 백준 / 스도쿠 / 2239

문제


문제 링크



접근 방식


  1. 0행 0열부터 8행 8열까지 오른쪽, 밑 방향으로 빈칸을 탐색한다.
  2. 빈칸을 만나면 1부터 9까지 가로 검사, 세로 검사, 네모 검사를 하고 빈칸에 해당 수를 넣을 수 있다면 넣은 후 다음 빈칸을 본다.
  3. 빈칸이 더 이상 없거나 8행 8열까지 모두 채웠다면 스도쿠를 완성시킨 것이다. 따라서 스도쿠를 출력하고 이후의 연산을 없앤다.


코드


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

public class Main_2239{

	static int[][] sudoku;
	static boolean isPrint;
	public static void main(String[] args) throws IOException{
		BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
		sudoku = new int[9][9];
		int blankCnt = 0;
		for(int i=0;i<9;i++) {
			String line = br.readLine();
			for(int j=0;j<9;j++) {
				sudoku[i][j] = line.charAt(j) - '0';
				if(sudoku[i][j] == 0) blankCnt++;
			}
		}
		isPrint = false;
		fill(0,0,blankCnt);
		
	}
	
	public static void fill(int r, int c, int blankCnt) {
		// 한번 출력 됬다면 나머지 연산을 파괴
		if(isPrint) return;
		
		// 한 행을 다 돌면 행 증가
		if(c == 9) {
			fill(r+1,0,blankCnt);
			return;
		}
		
		// 스도쿠를 모두 채웠다면 출력
		if(r == 9 || blankCnt == 0) {
			print();
			isPrint = true;
			return;
		}
		
		// 빈칸이라면 각 빈칸에 대해 1부터 9까지 대입해보기
		if(sudoku[r][c] == 0) {
			for(int i=1;i<=9;i++) {
				if(check(r,c,i)) { // 빈칸에 수를 대입했을 때 스도쿠가 성립되면
					sudoku[r][c] = i;
					fill(r,c+1,blankCnt-1); // 다음 빈칸으로 넘어감
					sudoku[r][c] = 0;
				}
			}
		}
		else {
			fill(r,c+1,blankCnt);
		}
		
		
	}
	
	public static boolean check(int r, int c, int val) {
		// 가로 검사
		for(int j=0;j<9;j++) {
			if(sudoku[r][j] == val) return false;
		}
		
		// 세로 검사
		for(int i=0;i<9;i++) {
			if(sudoku[i][c] == val) return false;
		}
		
		r = r/3*3;
		c = c/3*3;
		
		// 네모 검사
		for(int i=r;i<r+3;i++) {
			for(int j=c;j<c+3;j++) {
				if(sudoku[i][j] == val) return false;
			}
		}
		
		// 통과
		return true;
	}
	
	public static void print() {
		StringBuilder sb = new StringBuilder();
		for(int i=0;i<9;i++) {
			for(int j=0;j<9;j++) {
				sb.append(sudoku[i][j]);
			}
			sb.append("\n");
		}
		System.out.println(sb);
	}

}

0개의 댓글