验证数独

P1093 验证数独
时间: 1000ms / 空间: 131072KiB / Java类名: Main

背景

XX学校风靡一款智力游戏,也就是数独(九宫格),先给你一个数独,并需要你验证是否符合规则。

描述

具体规则如下:
每一行都用到1,2,3,4,5,6,7,8,9,位置不限,
每一列都用到1,2,3,4,5,6,7,8,9,位置不限,
每3×3的格子(共九个这样的格子)都用到1,2,3,4,5,6,7,8,9,位置不限,
游戏的过程就是用1,2,3,4,5,6,7,8,9填充空白,并要求满足每行、每列、每个九宫格都用到1,2,3,4,5,6,7,8,9。
如下是一个正确的数独:
5 8 1 4 9 3 7 6 2
9 6 3 7 1 2 5 8 4
2 7 4 8 6 5 9 3 1
1 2 9 5 4 6 3 7 8
4 3 6 1 8 7 2 9 5
7 5 8 3 2 9 1 4 6
8 9 2 6 7 1 4 5 3
6 1 5 9 3 4 8 2 7
3 4 7 2 5 8 6 1 9


输入格式

输入n个数独,你来验证它是否违反规则.
第一行为数独个数,第二行开始为第一个数独,之后为第二个,至第n个.
注意!每个数独之间有一个回车隔开!

输出格式

若正确则输出”Right”若不正确则输出”Wrong” 输出一个换一行

测试样例1

输入


5 8 1 4 9 3 7 6 2 
9 6 3 7 1 2 5 8 4 
2 7 4 8 6 5 9 3 1 
1 2 9 5 4 6 3 7 8 
4 3 6 1 8 7 2 9 5 
7 5 8 3 2 9 1 4 6 
8 9 2 6 7 1 4 5 3 
6 1 5 9 3 4 8 2 7 
3 4 7 2 5 8 6 1 9 

1 2 3 4 5 6 7 8 9 
2 3 4 5 6 7 8 9 1 
3 4 5 6 7 8 9 1 2 
4 5 6 7 8 9 1 2 3 
5 6 7 8 9 1 2 3 4 
6 7 8 9 1 2 3 4 5 
7 8 9 1 2 3 4 5 6 
8 9 1 2 3 4 5 6 7 
9 1 2 3 4 5 6 7 8

输出

Right 
Wrong
 

做了很久模拟然后突发奇想搞了个骗分,感觉没啥问题不知道为什么交上去只有80分WA了两个点。
骗分的思路:算总和,如果和不等于405就wrong;等于的话判断一下5出现的次数是不是81次是的话wrong,其他的全部right//因为全是5的话总和也是405
不过数据很弱没有全是5的情况。
 1 #include<iostream>
 2 #include<cstring>
 3 #include<cstdio>
 4 #include<algorithm>
 5 using namespace std;
 6 int n,a[15][15],sum=0,sf=0;
 7 int main()
 8 {
 9     cin>>n;
10     for(int i=1;i<=n;i++)
11     {
12         for(int j=1;j<=9;j++)
13         {
14             for(int k=1;k<=9;k++)
15             {
16                 scanf("%d",&a[j][k]);
17                 sum+=a[j][k];
18                 if(a[j][k]==5)++sf;
19                 if(k==9&&j==9){
20                     if(sum!=405){
21                         puts("Wrong");
22                         break;
23                     }
24                     if(sf==81){
25                         puts("Wrong");
26                         break;
27                     }
28                     else {
29                         puts("Right");
30                         break;
31                     }
32                 }
33                 
34             }
35         }
36     }
37     return 0;
38 }
骗分大法好

原文地址:https://www.cnblogs.com/gc812/p/5780683.html