From 771fb24ea3562502703f56030933b7f4abe3c090 Mon Sep 17 00:00:00 2001 From: tgyuu-An Date: Thu, 7 Mar 2024 23:06:02 +0900 Subject: [PATCH] 2024-03-07 --- .../\354\212\244\353\217\204\354\277\240.py" | 78 +++++++++++++++++++ tgyuuAn/README.md | 1 + 2 files changed, 79 insertions(+) create mode 100644 "tgyuuAn/DFS/\354\212\244\353\217\204\354\277\240.py" diff --git "a/tgyuuAn/DFS/\354\212\244\353\217\204\354\277\240.py" "b/tgyuuAn/DFS/\354\212\244\353\217\204\354\277\240.py" new file mode 100644 index 00000000..7905dc67 --- /dev/null +++ "b/tgyuuAn/DFS/\354\212\244\353\217\204\354\277\240.py" @@ -0,0 +1,78 @@ +import sys + +def input(): return sys.stdin.readline().rstrip() + +board = [] + +for _ in range(9): board.append(list(input())) + +def dfs(board, now_row, now_col): + + # 이미 들어있는 칸일 경우 + if board[now_row][now_col] != "0": + new_row = now_row + new_col = now_col + 1 + + if new_col >= 9: + new_col = 0 + new_row += 1 + + # 스도쿠 완성 + if new_row >= 9: return board + + temp = dfs(board, new_row, new_col) + + if temp is not None: return temp + + # 비어있는 칸일 경우 + else: + need_number = { str(x) for x in range(1,10) } + + # 가로 행 검사 + for col in range(9): + if board[now_row][col] != "0": + need_number.discard(board[now_row][col]) + + # 세로 행 검사 + for row in range(9): + if board[row][now_col] != "0": + need_number.discard(board[row][now_col]) + + # 3X3 검사 + temp_row = (now_row//3)*3 + temp_col = (now_col//3)*3 + for inner_row in range(temp_row, temp_row+3): + for inner_col in range(temp_col, temp_col+3): + if board[inner_row][inner_col] != "0": + need_number.discard(board[inner_row][inner_col]) + + # 만약 넣을 수 있는것이 없으면 None을 리턴 + if len(need_number) == 0: return None + + need_number = sorted(list(map(int,need_number))) + + for dedicate_number in need_number: + board[now_row][now_col] = str(dedicate_number) + + new_row = now_row + new_col = now_col + 1 + + if new_col >= 9: + new_col = 0 + new_row += 1 + + # 스도쿠 완성 + if new_row >= 9: return board + + temp = dfs(board, new_row, new_col) + + if temp is not None: return temp + + board[now_row][now_col] = "0" + + return None + +answer = dfs(board, 0, 0) + +for row in answer: + print("".join(row)) \ No newline at end of file diff --git a/tgyuuAn/README.md b/tgyuuAn/README.md index 530f4f4a..ab70aff5 100644 --- a/tgyuuAn/README.md +++ b/tgyuuAn/README.md @@ -42,4 +42,5 @@ | 38차시 | 2023.02.15 | DP | 피보나치 수 3 | https://github.com/AlgoLeadMe/AlgoLeadMe-1/pull/137 | 39차시 | 2023.02.18 | DP | | https://github.com/AlgoLeadMe/AlgoLeadMe-1/pull/139 | 40차시 | 2023.02.21 | DP | 입대 | https://github.com/AlgoLeadMe/AlgoLeadMe-1/pull/142 +| 42차시 | 2023.03.07 | DFS | 스도쿠 | https://github.com/AlgoLeadMe/AlgoLeadMe-1/pull/152 ---