鱼C论坛

 找回密码
 立即注册
查看: 904|回复: 5

[已解决]c语言作业,求大神帮忙

[复制链接]
发表于 2023-3-22 17:59:05 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
题目:
数独是有趣的数学游戏,玩家需要根据9×9盘面上的已知数字,推理出所有剩余空格的数字,并满足每一行、每一列、9个3*3的小方格内的数字均含1-9,不重复。但是为了简化题目,本题的数独只需要满足前两个要求即可。

即在本题中对于每一个数独(9*9):

1:每一行包含1-9。

2.每一列包含1-9。

输入格式:
9行9列,仅包含数字0-9。注意:0并不代表该数独位置的数字为0,而是该位置数字未知。每个测试样例仅包含一个未知数字。

输出格式:
输出满足题目要求的未知的那个数字。如果该处填写任何数字均不满足题目所描述的数独,则输出NO。

输入样例:
1 4 9 8 3 6 7 5 2
5 7 6 2 4 1 9 3 8
2 3 8 5 7 9 1 6 4
7 2 4 3 6 8 5 9 1
6 8 3 9 1 5 4 2 7
9 5 1 4 2 7 3 8 6
3 6 2 7 9 4 8 1 5
4 1 5 6 8 3 2 7 9
8 9 7 1 5 2 0 4 3
输出样例:
6
解释:将6填入0的位置中,这就是满足题目要求的正确数独。

输入样例:
1 4 9 8 3 6 7 5 2
5 7 6 2 4 1 9 3 8
2 3 8 5 7 9 1 6 4
7 2 4 3 6 8 5 9 1
6 8 3 9 1 5 4 2 7
9 5 1 4 2 7 3 8 6
3 6 2 7 9 4 8 1 5
4 1 5 6 8 3 2 7 9
8 9 7 1 5 2 0 4 4
输出样例:
NO
解释:最后一行有两个4,不满足数独每一行每一列不重复原则。

有思路,但不会写。。。。
最佳答案
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;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2023-3-22 18:37:10 | 显示全部楼层
引用:
这题其实很简单的哦~不如自己思考一下更好呢    ——小甲鱼
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-3-22 18:45:43 | 显示全部楼层
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-3-22 18:48:54 | 显示全部楼层
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 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;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2023-3-22 21:52:20 | 显示全部楼层
傻眼貓咪 发表于 2023-3-22 21:22
对于新手,这题确实有点难...

谢谢,大神。。。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-10-7 17:27

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表