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;
}

记得三连哦~

相关推荐
凌波粒1 小时前
LeetCode--100.相同的树(二叉树)
算法·leetcode·职场和发展
一条鱼头1 小时前
c++11语法点
开发语言·c++
Peter·Pan爱编程1 小时前
C++中的 const 与 volatile:比C强大十倍
c++·const·volatile·c++基础
lihao lihao1 小时前
MFC知识点
c++·mfc
Shadow(⊙o⊙)1 小时前
进程分析2.0——进程退出、进程等待-Linux重要经典模块
linux·运维·服务器·开发语言·c++·学习
无敌昊哥战神2 小时前
【机器学习扫盲】从预测 Score 到ACC、 Precision、Recall、ROC 曲线的白话全解
python·深度学习·算法·机器学习
奔跑的Ma~2 小时前
第6篇:蓝桥杯C++进阶突破(难题拆解+算法优化,冲刺国赛高奖)
c++·算法·蓝桥杯·#蓝桥杯备战·#c++编程·编程竞赛
数智工坊2 小时前
MPC引导的策略搜索:用模型预测控制训练安全高效的无人机深度控制策略
论文阅读·人工智能·算法·无人机
Lenyiin2 小时前
《LeetCode 顺序刷题》81 - 90
算法·leetcode