题解 | Sudoku
Sudoku
https://www.nowcoder.com/practice/78a1a4ebe8a34c93aac006c44f6bf8a1
import java.util.*;
// 注意类名必须为 Main, 不要有任何 package xxx 信息
public class Main {
static List<int[]> list;
static int[][] arr;
public static void main(String[] args) {
Scanner in = new Scanner(System.in);
arr = new int[9][9];
list = new ArrayList<>(); // 缺失数字的格子,即:需要填充的格子
for(int r = 0; r < 9; r++) {
for(int c = 0; c < 9; c++) {
arr[r][c] = in.nextInt();
if (arr[r][c] == 0) {
list.add(new int[]{r,c});
}
}
}
hand(0);
for(int r = 0; r < 9; r++) {
for(int c = 0; c < 9; c++) {
System.out.printf("%d ", arr[r][c]);
}
System.out.println();
}
}
// 从 arr 的 list[index] 位置开始填充, 返回所有格子是否填充完成
static boolean hand(int index) {
if (index == list.size()) {
return true;
}
// 枚举 1-9 每个数字来填充 arr[r][c]
int r = list.get(index)[0];
int c = list.get(index)[1];
for(int num = 1; num <= 9; num++) {
if (isValid(r, c, num)) {
arr[r][c] = num;
if (hand(index + 1)) {
return true;
}
arr[r][c] = 0;
}
}
return false;
}
// arr[r][c] 是否可以填充 num
static boolean isValid(int r, int c, int num) {
// 检查行,若当前行 r 已存在 num,说明不能填充
for(int col = 0; col < 9; col++) {
if (arr[r][col] == num) {
return false;
}
}
// 检查列
for(int row = 0; row < 9; row++) {
if (arr[row][c] == num) {
return false;
}
}
// 检查arr[r][c] 所属的 3*3 网格
int startRow = r / 3 * 3;
int startCol = c / 3 * 3;
for(int row = startRow; row < startRow + 3; row++) {
for(int col = startCol; col < startCol + 3; col++) {
if (arr[row][col] == num) {
return false;
}
}
}
return true;
}
}
查看4道真题和解析
三奇智元机器人科技有限公司公司福利 88人发布