LeetCode(37)

复制代码
class Solution {
public:
    void solveSudoku(vector<vector<char>>& board) {
        for(int i=0;i<9;i++){
            for(int j=0;j<9;j++){
                if(board[i][j]!='.'){
                    mt[0][i][board[i][j]-'1'] = true;
                    mt[1][j][board[i][j]-'1'] = true;
                    flag[i][j] = true;
                    n++;
                }
            }
        }
        for(int i=0;i<9;i++){
            for(int j=i/3*3;j<3+i/3*3;j++){
                for(int k=0+i%3*3;k<3+i%3*3;k++){
                    if(board[j][k]!='.'){
                        mt[2][i][board[j][k]-'1'] = true;
                    }
                }
            }
        }
        addNode(board,0,0);
    }
private:
    int n;
    bool flag[10][10],mt[3][10][10];
    bool isSudoku(vector<vector<char>>board,int p,int q,char c){
        int t = nSudoku(p,q);
        // cout<<p<<q<<t<<endl;
        if(mt[0][p][c-'1']||mt[1][q][c-'1']||mt[2][t][c-'1'])
            return false;
        return true;
    }
    int nSudoku(int p,int q){
        int i = p/3,j = q/3;
        return i*3+j;
    }
    bool addNode(vector<vector<char>>&board,int p,int q){
        if(n==81){        
            return true;
        }
        bool f2 = false,f3;
        int t,i,j;
        char c2;
        stack<int>s1,s2;
        for(i=p;i<9;i++){
            f3 = false;
            for(j=0;j<9;j++){
                if(board[i][j]=='.'){
                    f3 = true;
                    break;
                }
            }
            if(f3)break;
        }
        p = i;
        q = j;
        for(char c='1';c<='9';c++){
            if(board[p][q]=='.'&&isSudoku(board,p,q,c)){
                // cout<<p<<q<<c<<endl;
                t = nSudoku(p,q);
                s1.push(p);
                s2.push(q);
                mt[0][p][c-'1'] = mt[1][q][c-'1'] = mt[2][t][c-'1'] = true;
                board[p][q] = c;
                n++;
                // cout<<p<<q<<endl;
                if(addNode(board,p,q))return true;
                c2 = board[p][q];
                t = nSudoku(p,q);
                // cout<<p<<" "<<q<<c2-'1'<<endl;
                p = s1.top();
                q = s2.top();
                s1.pop();
                s2.pop();
                board[p][q] = '.';
                mt[0][p][c2-'1'] = mt[1][q][c2-'1'] = mt[2][t][c2-'1'] = false;
                n--;
            }
        }
        return false;
    }
};
复制代码

 

posted @   智人心  阅读(23)  评论(0编辑  收藏  举报
编辑推荐:
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· 写一个简单的SQL生成工具
· AI 智能体引爆开源社区「GitHub 热点速览」
· C#/.NET/.NET Core技术前沿周刊 | 第 29 期(2025年3.1-3.9)
点击右上角即可分享
微信分享提示