1026
来源:互联网 发布:增值税开票软件密码 编辑:程序博客网 时间:2024/06/06 07:24
题目编号:1026
题目大意:数独游戏。9*9的方格填数,每行列,九宫格都是1-9,现在求?处的数字。
解题大意:首先创建3个int类型的二维数组,一个存?的行列,两个存已有的行和列。循环将输入的例子导入,然后进行深搜。从第一个问号开始搜,当问号的数目为0即可退出。
如果没有到底,判断下一状态是否合法,判断行列和已存在的数字是否冲突,还有九宫图,用一个函数来判断那个九宫图中是否存在此数字,用1-9这个循环来试验到底 哪个合适,进行深搜下去。如果合法,进入下一状态。假如深搜下的不合法,要复原操作。最后判断是否搜出来输出即可。
感想:我一开始看了老师的代码,看懂了以后修改了直接提交的,然后就超时了,老师没有用函数判断九宫图,是用数组来储存的,提交就超时。然后我改成了函数来判断就A 了。
#include<iostream>#include<cstring>using namespace std;char arr[10][10];int i,j,brr[82][2];bool hang[10][10],lie[10][10];int k,m,n;bool check(int v,int num){ n=brr[v][0]/3*3; m=brr[v][1]/3*3; for(i=n;i<n+3;++i){ for(j=m;j<m+3;++j) { if(arr[i][j]==num+'0') return false; } } return true;}bool DFS(int v){ if(v==k) return true; for(i=1;i<10;++i) { if(!hang[brr[v][0]][i]&&!lie[brr[v][1]][i]&&check(v,i)) { arr[brr[v][0]][brr[v][1]]=i+'0'; hang[brr[v][0]][i]=true; lie[brr[v][1]][i]=true; if(DFS(v+1)) return true; arr[brr[v][0]][brr[v][1]]='?'; hang[brr[v][0]][i]=false; lie[brr[v][1]][i]=false; } } return false;}void output(){ for(int i=0;i<9;++i){ cout<<arr[i][0]; for(int j=1;j<9;++j){ cout<<" "<<arr[i][j]; } cout<<endl; } return;}int main(){ int num=0; while(1) { k=0; memset(hang,false,sizeof(hang)); memset(lie,false,sizeof(lie)); for(i=0;i<9;++i) { for(j=0;j<9;++j) { cin>>arr[i][j]; if(arr[i][j] == '?') { brr[k][0]=i; brr[k][1]=j; k++; continue; } hang[i][arr[i][j]-'0']=true; lie[j][arr[i][j]-'0']=true; } } k--; DFS(0); if(num++) cout<<endl; output(); } return 0;}
0 0
- 1026
- 1026
- 1026
- 1026
- 1026
- 1026
- 1026
- 1026
- 1026
- 1026
- 1026 Cipher
- POJ 1026
- hdu 1026
- PKU 1026
- POJ 1026
- HDU 1026
- poj 1026
- HDU-1026
- php字符串截取函数
- 漫游Kafka实战篇之客户端编程实例
- 金格签章使用时碰到的奇葩问题解决
- 新编日语第四册(修订版)
- MySQL日期处理相关
- 1026
- ZOJ 3326(E)模拟
- Android API Guides---Environment Sensors
- LeetCode_OJ【68】Text Justification
- Android 安全架构及权限控制机制剖析
- vb作业
- C语言之字符串的表示方式
- Matlab标定工具箱使用的一些注意事项
- lintcode之删除排序数组中的重复数字