数独口诀_数独技巧xwing推导过程

数独口诀_数独技巧xwing推导过程数独是一种传统益智游戏,你需要把一个 9×9 的数独补充完整,使得图中每行、每列、每个 3×3 的九宫格内数字 1∼9 均恰好出现一次。请编写一个程序填写数独。输入格式输入包含多组测试用例。每个测试用例占一行,包含 81 个字符,代表数独的 81 个格内数据(顺序总体由上到下,同行由左到右)。每个字符都是一个数字(1−9)或一个 .(表示尚未填充)。您可以假设输入中的每个谜题都只有一个解决方案。文件结尾处为包含单词 end 的单行,表示输入结束。输出格式每个测试用例,输出一行数据,代表填充

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

数独是一种传统益智游戏,你需要把一个 9×9 的数独补充完整,使得图中每行、每列、每个 3×3 的九宫格内数字 1∼9 均恰好出现一次。

请编写一个程序填写数独。

输入格式
输入包含多组测试用例。

每个测试用例占一行,包含 81 个字符,代表数独的 81 个格内数据(顺序总体由上到下,同行由左到右)。

每个字符都是一个数字(1−9)或一个 .(表示尚未填充)。

您可以假设输入中的每个谜题都只有一个解决方案。

文件结尾处为包含单词 end 的单行,表示输入结束。

输出格式
每个测试用例,输出一行数据,代表填充完全后的数独。

输入样例:
4.....8.5.3..........7......2.....6.....8.4......1.......6.3.7.5..2.....1.4......
......52..8.4......3...9...5.1...6..2..7........3.....6...1..........7.4.......3.
end
输出样例:
417369825632158947958724316825437169791586432346912758289643571573291684164875293
416837529982465371735129468571298643293746185864351297647913852359682714128574936

题解
剪枝策略:

  1. 有限分支数较少的节点。
  2. 排除等价冗余
  3. 可行性减枝
  4. 最优性减枝
  5. 记忆化搜索
#include<bits/stdc++.h>
using namespace std;
const int N = 9;
char g[N][N];
int col[N],row[N],grid[3][3];
int ones[1 << N];
int Map[1 << N];
int res = 0;
int sum = 0;
string line;
int get(int x,int y){ 
   
    return ones[row[x] & col[y] & grid[x / 3][y / 3]];
}
int lowbit(int x){ 
   
    return (x & (-x));
}
void push(int x,int y,int v){ 
   
    col[y] -= (1 << v);
    row[x] -= (1 << v);
    grid[x / 3][y / 3] -= (1 << v);
    int in = x * 9 + y;
    line[in] = '1' + v;
    g[x][y] = '1' + v;
}
void back(int x,int y,int v){ 
   
    col[y] += (1 << v);
    row[x] += (1 << v);
    grid[x / 3][y / 3] += (1 << v);
    int in = x * 9 + y;
    line[in] = '.';
    g[x][y] = '.';
}
bool dfs(int k){ 
   
    // cout<<k<<endl;
    if(k == sum){ 
   
        cout<<line<<endl;
        return true;
    }
    int x, y, v = 10;
    for(int i = 0;i < N;i ++){ 
   
        for(int j = 0;j < N;j ++){ 
   
            if(g[i][j] == '.'){ 
   
                if(v > get(i,j)){ 
   
                    v = get(i , j);
                    x = i,y = j;
                }
            }
        }
    }
    int t = col[y] & row[x] & grid[x / 3][y / 3];
    while(t > 0){ 
   
        int tt = lowbit(t);
        t -= tt;
        push(x,y,Map[tt]);
        if(dfs(k + 1))return true;
        back(x,y,Map[tt]);
    }
    return false;
}
int main(){ 
   
    for(int i = 0;i < 1 << N;i ++){ 
   
        for(int j = 0;j < N;j ++){ 
   
            if((i >> j) & 1)ones[i] ++;
        }
    }
    for(int i = 0;i < N;i ++)Map[1 << i] = i;
    while(cin>>line,line != "end"){ 
   
        for(int i = 0;i < line.size();i ++){ 
   
            int x = i / N,y = i % N;
            g[x][y] = line[i];
        }
        memset(col,0,sizeof col);
        memset(row,0,sizeof row);
        memset(grid,0,sizeof grid);
        sum = 0;
        for(int i = 0;i < N;i ++){ 
   
            col[i] = (1 << N) - 1;
            row[i] = (1 << N) - 1;
            grid[i / 3][i % 3] = (1 << N) - 1;
        }
        for(int i = 0;i < N;i ++){ 
   
            for(int j = 0;j < N;j ++){ 
   
                if(g[i][j] != '.'){ 
   
                    int x = g[i][j] - '1';
                    col[j] -= (1 << x);
                    row[i] -= (1 << x);
                    grid[i / 3][j / 3] -= (1 << x);
                }else sum ++;
            }
        }
        dfs(0);
    }
    return 0;
}
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/169137.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • 深入Redis客户端(redis客户端属性、redis缓冲区、关闭redis客户端)「建议收藏」

    深入Redis客户端(redis客户端属性、redis缓冲区、关闭redis客户端)「建议收藏」Redis数据库采用I/O多路复用技术实现文件事件处理器,服务器采用单线程单进程的方式来处理多个客户端发送过来的命令请求,它同时与多个客户端建立网络通信。服务器会为与它相连接的客户端创建相应的redis.h/redisClient结构,在这个结构中保存了当前客户端的相关属性及执行相关功能时的数据结构。I/O多路复用:linux有五类io模型1.阻塞2.非阻塞3…

  • U盘启动制作教程/实例 新手制作启动盘必看! [20081120]「建议收藏」

    U盘启动制作教程/实例 新手制作启动盘必看! [20081120]「建议收藏」总结几点优盘量产前的准备工作和注意事项 http://bbs.mydigit.cn/read.php?tid=79204 ———————————————————————– 附上总版搜集的一些U盘量产工具使用操作说明手册 http://bbs.mydigit.cn/read.php?tid=

  • ffplay播放器移植VC的工程:ffplay for MFC[通俗易懂]

    ffplay播放器移植VC的工程:ffplay for MFC[通俗易懂]ffplay播放器移植VC的工程:ffplayforMFC本文介绍一个自己做的FFPLAY移植到VC下的开源工程:ffplayforMFC。本工程将ffmpeg项目中的ffplay播放器(ffplay.c)移植到了VC的环境下。并且使用MFC做了一套简单的界面。它可以完成一个播放器播放视频的基本流程:解协议,解封装,视频/音频解码,视音频同步,视音频输出。此外还包含一些控制功能:播放,暂停/继

  • KindEditor配置ctrl+enter提交

    KindEditor配置ctrl+enter提交今天花费了一些时间去想怎么配置,网上也没有直接找到这方面的资料。后面突然看到一个网页,提交也是用了相同的编辑器。就学习了一下。//创建编辑器functioncreateEditor(){KindEditor.ready(function(K){ChatEditor=K.create(‘textarea.win_chat_textarea’,{width:’100%’,

    2022年10月10日
  • python入门教程(非常详细)书_python编程入门基础

    python入门教程(非常详细)书_python编程入门基础【Python第1课】安装…6【Python第2课】print.7【Python第3课】IDE.10【Python第4课】输入…12【Python第5课】变量…14【Python第6课】bool.16【Python第7课】if.19【Python第8课】while.23【Python第9课】random.

    2022年10月12日
  • 碟刹和V刹的区别「建议收藏」

    碟刹和V刹的区别「建议收藏」0首先拍死的一个观点就是碟刹比V刹要好,要高档──似乎大部分对于运动自行车陌生新手往往认为碟刹一定比V刹要好,我们听到过这样的话:“都2000多的车了,还没有碟刹”───这样的话真的让人哭笑不得,看看不论是国外的比赛还是国内的专业比赛,如果是晴天的比赛,V刹车还是占了大部分的,当然目前也有碟刹车增多的趋势,但是对于大部分休闲骑行和不参加业余级别比赛的车友的来说,V刹尤其是好些的V刹还是够用的,…

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号