这是第一次写中等题,但结果还是很差…不想用暴力算法,但自己又无法想到一个算法去解决
官方解法:
class Solution {
public boolean isValidSudoku(char[][] board) {
int[][] rows = new int[9][9];
int[][] columns = new int[9][9];
int[][][] subboxes = new int[3][3][9];
for (int i = 0; i < 9; i++) {
for (int j = 0; j < 9; j++) {
char c = board[i][j];
if (c != '.') {
int index = c - '0' - 1;
rows[i][index]++;
columns[j][index]++;
subboxes[i / 3][j / 3][index]++;
if (rows[i][index] > 1 || columns[j][index] > 1 || subboxes[i / 3][j / 3][index] > 1) {
return false;
}
}
}
}
return true;
}
}
设置一个装每一行的二维数组,分别记行数和该数字出现的次数
然后一个每一列的二维数组,分别记列数和该数字出现的次数
然后数独的9个数字的小区域,只需他原本的列数或者行数/3,就是相对应的小区域的位置。。
这道题的思路也很简单,没有什么复杂的算法思想,但是就是按着一个很好的逻辑写下来了,时间复杂度也只有O(1)