上海市计算机学会竞赛平台2024年9月月赛丙组数独验证

题目描述

数独是一种智力游戏。给定 9×99×9 个整数构成的矩阵,请验证这些整数的排列方式是否符合数独的条件。

一个合法的数独要求矩阵在每一行、每一列、每个宫都含有 11 到 99 的全部数字。所谓宫是指矩阵前三行、中三行、后三行与前三列、中三列、后三列组成的九个 3×33×3 的小矩阵。

输入格式
  • 九行整数:每行九个数字表示一个矩阵。
输出格式
  • 若满足数独条件,输出 Valid,否则输出 Invalid
数据范围
  • 保证输入的每个数字均为 11 到 99 的整数。
样例数据

输入:

8 4 5 9 3 1 6 2 7

9 1 6 5 2 7 8 3 4

7 3 2 6 4 8 9 5 1

5 7 8 4 9 3 2 1 6

2 6 1 8 7 5 3 4 9

4 9 3 2 1 6 5 7 8

6 8 7 1 5 2 4 9 3

3 5 9 7 6 4 1 8 2

1 2 4 3 8 9 7 6 5

输出:

Valid

输入:

1 1 1 2 2 2 3 3 3

4 4 4 5 5 5 6 6 6

7 7 7 8 8 8 9 9 9

1 1 1 2 2 2 3 3 3

4 4 4 5 5 5 6 6 6

7 7 7 8 8 8 9 9 9

1 1 1 2 2 2 3 3 3

4 4 4 5 5 5 6 6 6

7 7 7 8 8 8 9 9 9

输出:

Invalid

详见代码:

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
int n = 9;
int a[10][10];
bool b[10];
int main() 
{
    for(int i = 1; i <= n; i++) 
    {
        for(int j = 1; j <= n; j++) 
        {
            cin >> a[i][j];
        }
    }
    for(int i = 1; i <= n; i++) 
    { 
        memset(b, 0, sizeof(b));
        for(int j = 1; j <= n; j++) 
        { 
            b[a[i][j]] = 1;
        }
        for(int j = 1; j <= n; j++) 
        { 
            if(b[j] != 1) 
            { 
                cout << "Invalid";
                return 0;
            }
        }
    }
    for(int i = 1; i <= n; i++) 
    {
        memset(b, 0, sizeof(b));
        for(int j = 1; j <= n; j++) 
        {
            b[a[j][i]] = 1;
        }
        for(int j = 1; j <= n; j++) 
        {
            if(b[j] != 1) 
            {
                cout << "Invalid";
                return 0;
            }
        }
    }
    for(int k = 1; k <= n; k += 3) 
    { 
        for(int l = 1; l <= n; l += 3) 
        {
            memset(b, 0, sizeof(b));
            for(int i = k; i < k + 3; i++) 
            {
                for(int j = l; j < l + 3; j++) 
                {
                    b[a[j][i]] = 1;
                }
            }
            for(int j = 1; j <= n; j++)
            {
                if(b[j] != 1) 
                {
                    cout << "Invalid";
                    return 0;
                }
            }
        }
    }
    cout << "Valid";
    return 0 ;
}
相关推荐
未来之窗软件服务5 小时前
自己写算法(九)网页数字动画函数——东方仙盟化神期
前端·javascript·算法·仙盟创梦ide·东方仙盟·东方仙盟算法
豐儀麟阁贵6 小时前
基本数据类型
java·算法
乐迪信息7 小时前
乐迪信息:基于AI算法的煤矿作业人员安全规范智能监测与预警系统
大数据·人工智能·算法·安全·视觉检测·推荐算法
hsjkdhs8 小时前
C++之多层继承、多源继承、菱形继承
开发语言·c++·算法
立志成为大牛的小牛8 小时前
数据结构——十七、线索二叉树找前驱与后继(王道408)
数据结构·笔记·学习·程序人生·考研·算法
星空下的曙光8 小时前
Node.js crypto模块所有 API 详解 + 常用 API + 使用场景
算法·node.js·哈希算法
StarPrayers.10 小时前
旅行商问题(TSP)(2)(heuristics.py)(TSP 的两种贪心启发式算法实现)
前端·人工智能·python·算法·pycharm·启发式算法
爱吃橘的橘猫10 小时前
嵌入式系统与嵌入式 C 语言(2)
c语言·算法·嵌入式
2351610 小时前
【LeetCode】146. LRU 缓存
java·后端·算法·leetcode·链表·缓存·职场和发展
weixin_3077791311 小时前
使用Python高效读取ZIP压缩文件中的UTF-8 JSON数据到Pandas和PySpark DataFrame
开发语言·python·算法·自动化·json