|
发表于 2023-3-22 21:22:54
|
显示全部楼层
本楼为最佳答案
 对于新手,这题确实有点难...
- #define _CRT_SECURE_NO_WARNINGS
- #include <stdio.h>
- // 检查每一行的数字均含 1-9,不重复。
- int rowCheck(int sudoku[9][9], int row, int num) {
- for (int col = 0; col < 9; ++col) {
- if (sudoku[row][col] == num) {
- return 0;
- }
- }
- return 1;
- }
- // 检查每一列的数字均含 1-9,不重复。
- int columnCheck(int sudoku[9][9], int col, int num) {
- for (int row = 0; row < 9; ++row) {
- if (sudoku[row][col] == num) {
- return 0;
- }
- }
- return 1;
- }
- // 检查 3*3 的小方格内的数字均含 1-9,不重复。
- int boxCheck(int sudoku[9][9], int row, int col, int num) {
- int i1 = row / 3 * 3, i2 = i1 + 3,
- j1 = col / 3 * 3, j2 = j1 + 3;
- for (int i = i1; i < i2; ++i) {
- for (int j = j1; j < j2; ++j) {
- if (sudoku[i][j] == num) {
- return 0;
- }
- }
- }
- return 1;
- }
- // 检查全部位置不重复
- int checkAll(int sudoku[9][9]) {
- int nums[9] = { 0 };
- for (int row = 0; row < 9; ++row) {
- for (int col = 0; col < 9; ++col) {
- if (sudoku[row][col]) {
- nums[sudoku[row][col] - 1]++;
- }
- }
- // 检查和重置
- for (int i = 0; i < 9; ++i) {
- if (nums[i] > 1) return 0;
- nums[i] = 0;
- }
- }
- for (int col = 0; col < 9; ++col) {
- for (int row = 0; row < 9; ++row) {
- if (sudoku[row][col]) {
- nums[sudoku[row][col] - 1]++;
- }
- }
- // 检查和重置
- for (int i = 0; i < 9; ++i) {
- if (nums[i] > 1) return 0;
- nums[i] = 0;
- }
- }
- return 1;
- }
- int main(void) {
- int sudoku[9][9] = { 0 }, i, j, flag1 = 1, flag2 = 0;
- for (int row = 0; row < 9; ++row) {
- for (int col = 0; col < 9; ++col) {
- scanf("%d", &sudoku[row][col]);
- if (!sudoku[row][col]) {
- i = row;
- j = col;
- }
- }
- }
- // 先检查数独是否符合条件
- if (!checkAll(sudoku)) flag1 = 0;
- // 检查位置 0 的未知数是什么数?
- for (int num = 1; num <= 9 && flag1; ++num) {
- if (rowCheck(sudoku, i, num) && columnCheck(sudoku, j, num) && boxCheck(sudoku, i, j, num)) {
- printf("%d\n", num);
- flag2 = 1;
- break;
- }
- }
- // 诺都不符合条件,输出 NO
- if (!(flag1 && flag2)) {
- printf("NO\n");
- }
- return 0;
- }
复制代码 |
|