P16473 [GKS 2013 #B] Sudoku Checker题解

本题纯

鉴于数据范围比较小,按题意模拟即可。

依次检查每一行,每一列和每一个子矩阵是否符合要求。

注意多测和题目要求的格式化输出。

AC Code

cpp 复制代码
#include <bits/stdc++.h>
#define int long long
#define endl "\n"
using namespace std;

const int MAXN = 45;
int tmp, n, a[MAXN][MAXN];
bool vis[MAXN];

bool check() {
    int sz = n;
    int blk = tmp;
    // 1. 检查每一行
    for (int i = 1; i <= sz; i++) {
        memset(vis, 0, sizeof(vis));
        for (int j = 1; j <= sz; j++) {
            int num = a[i][j];
            if (vis[num]) return false;
            vis[num] = true;
        }
    }
    // 2. 检查每一列
    for (int j = 1; j <= sz; j++) {
        memset(vis, 0, sizeof(vis));
        for (int i = 1; i <= sz; i++) {
            int num = a[i][j];
            if (vis[num]) return false;
            vis[num] = true;
        }
    }
    // 3. 检查每一个子矩阵
    for (int i = 1; i <= sz; i += blk) {
        for (int j = 1; j <= sz; j += blk) {
            memset(vis, 0, sizeof(vis));
            for (int dx = 0; dx < blk; ++dx) {
                for (int dy = 0; dy < blk; ++dy) {
                    int x = i + dx;
                    int y = j + dy;
                    int num = a[x][y];
                    if (vis[num]) return false;
                    vis[num] = true;
                }
            }
        }
    }
    return true;
}

void solve(int case_id) {
    cout << "Case #" << case_id << ": ";
    memset(a, 0, sizeof(a));
    cin >> tmp;
    n = tmp * tmp;
    for (int i = 1; i <= n; i++) {
        for (int j = 1; j <= n; j++) {
            cin >> a[i][j];
            if (a[i][j] < 1 || a[i][j] > n) {
                for (int k = j + 1; k <= n; k++) cin >> a[i][k];
                for (int k = i + 1; k <= n; k++)
                    for (int l = 1; l <= n; l++) cin >> a[k][l];
                cout << "No\n";
                return;
            }
        }
    }
    if (check()) cout << "Yes\n";
    else cout << "No\n";
}

signed main() {
    cin.tie(0) -> sync_with_stdio(0);
    int t; cin >> t;
    for (int i = 1; i <= t; i++) solve(i);
    return 0;
}

记得三连哦~

相关推荐
用户805533698036 小时前
不止三件套:QObject 属性系统全关键字与运行时反射!
c++·qt
To_OC16 小时前
LC 207 课程表:刚学图论那会儿,我连这是拓扑排序都没看出来
javascript·算法·leetcode
To_OC16 小时前
LC 208 实现 Trie 前缀树:曾被名字劝退,写完发现是送分题
javascript·算法·leetcode
BadBadBad__AK18 小时前
线段树维护区间 k 次方和
c++·数学·算法·stl
卷无止境1 天前
Eigen 库如何借助 OpenMP 加速计算
c++·后端
_清歌1 天前
DSpark 深度解读:DeepSeek-V4 如何用「半自回归」把推理速度提升 85%
算法
统计实现局1 天前
SVD 的三步走:双对角化、Givens 收敛、排序
算法
躬行见万象1 天前
《VLA 系列》UniLab 强化训练 | G1 机器人 |复现
算法
统计实现局1 天前
对称不定分解(Bunch-Kaufman):为什么 Cholesky 不够用
算法