求解数独sudoku问题 9*9c++代码_拍张照片求解数独,计算机如何从图中看懂题目,这个GitHub热榜项目告诉你...

6485a69623344d12d307bb55cd415f04.png

来源:和讯网

 现在只需拍张照片,就能快速解决数独问题了。

  数独对计算机来说不是什么难事,但就是这样一个“平平无奇”的项目却登上了GitHub今日的热榜。   这个登上热榜的项目,名字就叫AI Sudoku,其实就是用AI里的计算机视觉,把照片变成计算机能看懂的网格和数字。 2e082e796ebdcc79b3a51c19f0967824.png   接下来求解数独问题当然不难。 重要的是,在这个过程中,我们也学习到了一些常用的计算机图片处理算法。   拍张照片解数独   智能数独求解器(Smart Sudoku Solver)的安装使用并不复杂,只需把项目代码克隆到本地即可。   Windows系统下支持图形化界面,把拍摄图片传输到电脑上就能给出答案。   首次运行需要连接网络下载MNIST数据集,训练模型并创建knn.sav文件,整个过程可能需要5~10分钟,之后就可以离线运行了。   python Run.py   运行上面的代码后,将显示KNN算法的训练结果 d016d78caedf22e632b123be425963c9.png   之后将很快出现GUI界面,选择上传你拍摄的数独谜题图片。 b6166798df81a82a46bede8152c32216.png   一直点击下一步,就能得到这道题的答案: 9bb8b93dca80c7164797a8e09017d85e.png   原理   作者在程序中提供了卷积神经网络或k近邻两种算法,供你选择。   运行应用程序之前,只需将Run.py文件中的modeltype变量设置为“CNN”或“KNN”。 默认情况下,程序设置为“ KNN”,而且现阶段使用KNN可以获得更高的准确性。   '''Run this file to run the application'''   from MainUI import MainUI   from CNN import CNN   from KNN import KNN   import os   # Change the model type variable value to "CNN" to use the Convolutional Neural Network   # Change the model type variable value to "KNN" to use the K Nearest Neighbours Classifier   modeltype = "KNN"   在我们点击“下一步”的过程中,程序展示了图片处理的步骤。   首先是对图片进行高斯模糊处理,去除噪声和其他细节。 b5afc842ca7ad01def6ad2cdace98496.png   接下来,生成一张清晰的扫描图。 由于一张图片中不同区域的光照,采用自适应高斯阈值的方法可以避免这一问题: 28b55d72a9a8fc56f799ac6ef0f3d0f9.png   反转图片,让文字和网格都变成白色,背景变成黑色。 61f4f0ca95d8d227a572fd2f840e20ba.png   之后找出边缘的四条线,通过这四条线,将拍到的数独题目变成一张正方形图片。 c9032c726899c96f80f144447fd8285e.png   最后将图片切割成81个小块,识别出每个小块里的数字。   传送门   求解数独问题并不是很难,这个开源项目的作用其实是帮你了解图像识别和处理的各种算法,例如高斯模糊、自适应高斯阈值等等。   项目对这些算法的名称和介绍都做了适当的加粗处理,如果你对这些感兴趣,不妨前去观摩学习一下。   源代码地址:   https://github.com/neeru1207/AI_Sudoku

ec83d862aab39a26b4fc0bc2386d9ab3.png

5b67d4833f8a76fc8b2ab3c36c54f7fe.png

8aecc102eaad9a027506aacd8a045843.png

bb7581219dc131603c182ecdb21f7dc9.png bd21da94e5a6474e94b05a6a02be2c92.png 48af635ade20a43f713c8cf6edbfe7b2.png 59519b4116d0e33e96611412fe37fbb8.png e5809be45053a4095ec2343bd2862aea.png 6e6a1d02def830e75d01875b1dba06c1.png 39b29c09df8760e940a5fa1741e36aca.png 233b56d26147d95781a73833b11f31da.png 64400f6c7caade61c884d73b23c411e5.png

b86a0ab2d34c93be0c47ebd00de0e20c.png

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
可以使用回溯算法来解决MATLAB数独问题。以下是一个MATLAB代码示例: function res = solveSudoku(sudoku) % 初始化数独矩阵 for i = 1:9 for j = 1:9 if sudoku(i,j) == 0 sudoku(i,j) = [1:9]; end end end % 开始回溯 s = []; % 用来保存可选数字的栈 i = 1; j = 1; while i <= 9 && i >= 1 && j <= 9 && j >= 1 if length(sudoku(i,j)) == 1 % 当前位置已经有确定的数字 % 检查同行、同列、同九宫格是否有相同的数字 for k = [1:i-1 i+1:9] if sudoku(k,j) == sudoku(i,j) error('无解!'); end end for k = [1:j-1 j+1:9] if sudoku(i,k) == sudoku(i,j) error('无解!'); end end row = 3*ceil(i/3-1)+1:3*ceil(i/3); col = 3*ceil(j/3-1)+1:3*ceil(j/3); for k = row for l = col if sudoku(k,l) == sudoku(i,j) error('无解!'); end end end % 确定下一个位置 if j == 9 i = i + 1; j = 1; else j = j + 1; end elseif length(sudoku(i,j)) == 0 % 需要回溯 if isempty(s) error('无解!'); end sudoku(i,j) = s{end}(end); s{end}(end) = []; if isempty(s{end}) s(end) = []; end if j == 1 i = i - 1; j = 9; else j = j - 1; end else % 确定当前位置 num = sudoku(i,j)(1); sudoku(i,j)(1) = []; s{end+1} = sudoku(i,j); % 检查同行、同列、同九宫格是否有相同的数字 for k = [1:i-1 i+1:9] sudoku(k,j)(sudoku(k,j) == num) = []; if length(sudoku(k,j)) == 0 error('无解!'); elseif length(sudoku(k,j)) == 1 s{end+1} = sudoku(k,j); end end for k = [1:j-1 j+1:9] sudoku(i,k)(sudoku(i,k) == num) = []; if length(sudoku(i,k)) == 0 error('无解!'); elseif length(sudoku(i,k)) == 1 s{end+1} = sudoku(i,k); end end row = 3*ceil(i/3-1)+1:3*ceil(i/3); col = 3*ceil(j/3-1)+1:3*ceil(j/3); for k = row for l = col sudoku(k,l)(sudoku(k,l) == num) = []; if length(sudoku(k,l)) == 0 error('无解!'); elseif length(sudoku(k,l)) == 1 s{end+1} = sudoku(k,l); end end end % 确定下一个位置 if j == 9 i = i + 1; j = 1; else j = j + 1; end end end % 将数独矩阵转换为输出格式的字符串 res = ''; for i = 1:9 for j = 1:9 res = [res sprintf('%d',sudoku(i,j))]; end end end 使用时需要输入一个9x9的整数矩阵表示数独,其0表示未填数字。该函数返回解出的数独,若无解则抛出异常。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值