openjudge 2982--Sudoku(九宫格数独) DFS算法加剪枝

题目链接:http://bailian.openjudge.cn/practice/2982/

#include <iostream>
#include <cstring>
using namespace std;
int t[10][10];
bool flag;
bool ok=false;
void dfs(int m,int n){
	if(ok) return;
	if(m==9&&n==10){
		for(int i=1;i<10;++i){
			for(int j=1;j<10;++j){
				cout<<t[i][j];
			}
			cout<<endl;
		}
		ok=true;
		return;
	}else{
		if(n==10){
			dfs(m+1,0);
			return;
		}
		if(t[m][n]!=0){
			dfs(m,n+1);
			return;
		}

		for(int i=9;i>=1;--i){
			flag=true;
			for(int y=1;y<10;++y){
				if(t[m][y]==i){
					flag=false;
					break;
				}
			}
			if(flag){
				for(int x=1;x<10;++x){
					if(t[x][n]==i){
						flag=false;
						break;
					}
				}
			}

				
			if(flag){
				int pos_x,pos_y;
				if(m%3!=0){
					pos_x=(m/3)*3;
				}else{
					pos_x=m-3;
				}
				if(n%3!=0){
					pos_y=(n/3)*3;
				}else{
					pos_y=n-3;
				}
				for(int x=pos_x+1;x<=pos_x+3;++x){
					for(int y=pos_y+1;y<=pos_y+3;++y){
						if(t[x][y]==i){
							flag=false;
							goto X;
						}
					}
				}
			}

			X:
			if(flag==true){
				t[m][n]=i;
				dfs(m,n+1);
				if(ok) return;
				t[m][n]=0;
			}
		}
	}

}


void sudoku(){
	std::ios::sync_with_stdio(false);
	std::cin.tie(0);
	int n;
	cin>>n;
	char s[20][20];
	while(n--){
		ok=false;
		for(int i=0;i<9;++i){
			cin>>s[i];
		}
		for(int i=1;i<10;++i){
			for(int j=1;j<10;++j){
				t[i][j]=s[i-1][j-1]-'0';
			}
		}
		dfs(1,1);
	}

}

int main(){
	sudoku();
	return 0;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值