递归回溯生成和解决数独问题c/c++
数独
程序地址https://github.com/papicheng/blog/tree/master/%E6%95%B0%E7%8B%AC
一、游戏规则介绍:
数独是源自18世纪瑞士的一种数学游戏。是一种运用纸、笔进行演算的逻辑游戏。玩家需要根据9×9盘面上的已知数字,推理出所有剩余空格的数字,并满足每一行、每一列、每一个粗线宫(3*3)内的数字均含1-9,不重复。
- 程序介绍:
- 数独生成程序(sudokuGenerate.cpp)
生成数独的算法思想:回溯法,递归实现深度优先搜索
函数简介:
- void randomFirstRow(char a0[], int n) /*随机生成第一行*/
- int Digit(char a[][COL], int i, int j)/*递归填充一个数字*/
- void createSudoku(char a[][COL])/*封装后的数独生成函数*/
- void createStartinggrid(const char a[][COL], char b[][COL], int numDigits)/*随机生成初盘*/
- int checkSudoku(const char a[][COL])/*按规则检查函数*/
- void printToFile(const char a[][COL], const char filename[])/*打印数独数组到文件*/
- void createSudokuToFile(void)/*批量生成数独初盘到文件中*/
主要变量:
#define MAXNUM 1000 /*数独游戏个数*/
#define SEED 20171212 /*用于随机数生成的种子*/
- 模拟学生端程序(sudokuStudentEnd.cpp)
解决数独问题的算法思想:与生成数独一致。
函数简介:
- int checkSudoku(const char a[][COL])/*按规则检查函数*/
- void printSudoku(const char a[][COL])/*打印数独到屏幕*/
- void readFromFile(char a[][COL],
const char filename[])/*从一个文件中读取数独*/
- int Solve(const char a[][COL],char b[][COL], int i,
int j)/*递归解决数独*/
- void solveSudoku(const char a[][COL],
char b[][COL])/*封装后的解数独函数*/
- 主函数负责遍历读取sudoku目录中的全部数独初盘,调用解数独函数,并计算时间,检查解的正确性,如果出错立刻输出错误提示并结束程序。最后输出求解全部数独问题花费的时间。
主要变量:
#define MAXNUM 1000 /*数独游戏个数,初始阶段可以设置成100,即 只做前100道题*/
- 待解决程序(sudokuStudentEnd_toBeSolved.cpp)
内容与模拟学生端程序基本一致,主要做了以下修改:
- 删除readFromFile函数的函数体,考察学生的文件读写能力;
- 删除Solve函数;
- 删除solveSudoku函数的函数体。其中:
- 参数const char a[][COL]表示初盘二维数组;
- 参数char b[][COL]表示解的二维数组。
- 任务要求:
- 老师利用sudokuGenerate.cpp生成包含1000道数独问题的sudoku文件夹;
- 将sudoku文件夹和sudokuStudentEnd_toBeSolved.cpp发布给学生(sudoku文件夹和sudokuStudentEnd_toBeSolved.cpp必须在同一目录下);
- 学生需要补充readFromFile函数和Solve函数,完成1000道数独问题的求解。
- 并且,程序的运行时间必须低于模拟学生端程序的时间(200s以内)。
- 评分标准:
- 正确解决数独问题,并且时间控制在200s以内可以得到满分。
- 用时最短的前三名学生获得额外的分数奖励。
程序运行效果图
注:生成的数独会以TXT文件格式保存,解算数独的时候需要从txt文件中读取数据。
程序地址https://github.com/papicheng/blog/tree/master/%E6%95%B0%E7%8B%AC
如果对您有帮助
递归回溯生成和解决数独问题c/c++的更多相关文章
- POJ2676,HDU4069解决数独的两种实现:DFS、DLX
搜索实现:解决数独有两种思考策略,一种是枚举当前格能填的数字的种数,这里有一优化策略就是先搜索能填入种数小的格子:另一种是考虑处理某一行(列.宫)时,对于某一个没用过的数字,若该行(列.宫)只有一个可 ...
- LeetCode || 递归 / 回溯
呜呜呜 递归好不想写qwq 求“所有情况”这种就递归 17. Letter Combinations of a Phone Number 题意:在九宫格上按数字,输出所有可能的字母组合 Input: ...
- 20191030-带返回值的回溯算法Leetcode解数独
题目描述 编写一个程序,通过已填充的空格来解决数独问题. 一个数独的解法需遵循如下规则: 数字 1-9 在每一行只能出现一次. 数字 1-9 在每一列只能出现一次. 数字 1-9 在每一个以粗实线分隔 ...
- 【原创】视频+文字:详解VBA解决数独问题
[说在前面]: 之前,我在微信朋友圈看到一个同事发了一个状态,说的是她在家辅导孩子做作业,一个数独的题目,好像没有做出来.我看了下,我也做不出来,后来仔细想了下,花了两个多小时时间,用Python编了 ...
- SQL Server中公用表表达式 CTE 递归的生成帮助数据,以及递归的典型应用
本文出处:http://www.cnblogs.com/wy123/p/5960825.html 我们在做开发的时候,有时候会需要一些帮助数据,必须需要连续的数字,连续间隔的时间点,连续的季度日期等等 ...
- 公用表表达式(CTE)递归的生成帮助数据
本文的作者辛苦了,版权问题特声明本文出处:http://www.cnblogs.com/wy123/p/5960825.html 工作有时候会需要一些帮助数据,必须需要连续的数字,连续间隔的时间点,连 ...
- 递归回溯 UVa140 Bandwidth宽带
本题题意:寻找一个排列,在此排序中,带宽的长度最小(带宽是指:任意一点v与其距离最远的且与v有边相连的顶点与v的距离的最大值),若有多个,按照字典序输出最小的哪一个. 解题思路: 方法一:由于题目说结 ...
- SQL点点滴滴_公用表表达式(CTE)递归的生成帮助数据
本文的作者辛苦了,版权问题特声明本文出处:http://www.cnblogs.com/wy123/p/5960825.html 工作有时候会需要一些帮助数据,必须需要连续的数字,连续间隔的时间点,连 ...
- php 递归的生成目录函数
/** * 递归的生成目录 * @param str $dir 必须是目录 */ function mkdirs($dir) { return is_dir($dir) ?: mkdirs(dirna ...
随机推荐
- java 任务定时调度(定时器)
任务定时调度 通过Timer和Timetask,我们可以实现定时启动某个线程. java.util.Timer 在这种实现方式中,Timer类作用是类似闹钟的功能,也就是定时或者每隔一定时间触发一次线 ...
- Spring Security Oauth2 : Possible CSRF detected
Spring Security Oauth2 : Possible CSRF detected 使用Spring Security 作为 Oauth2 授权服务器时,在授权服务器登录授权后,重定向到客 ...
- 扩展支持全选的CheckBox列。
扩展支持全选的CheckBox列. https://www.codeproject.com/articles/42437/toggling-the-states-of-all-checkboxes-i ...
- Action请求后台出现Response already commited异常解决方法
在编写导出功能使用action请求,在处理导出异常时期望跳转异常页,Controller中的方法返回类型String的url 在处理完逻辑导出文件后后台控制台出现 WARN [org.springf ...
- 如何导出robotframework的工程
不知道是不是只有我一个小白,自己折腾了很久,也百度了很久,不知道怎么导出哇.现在来扫扫盲罗.我拿自己的项目举例:找到我的RF工程目录可以看到下面有3个项目,直接拷贝你想要的项目就ok啦,是不是so e ...
- 如何去把内容分享到whatsapp上?
使用场景,公司利用whatsapp来推广商品,需要把商品和一些基本信息分享到WhatsApp上; 一:在html的head标签里面通过meta标签加上一些分享的基本网站信息,具体代码如下 <me ...
- vue中组件之间的通信
一.vue中组件通信的种类 父组件向子组件的通信 子组件向父组件的通信 隔代组件之间的通信 兄弟 组件 之间的通信 二.实现通信的方式 props vue自定义的事件 消息订阅与发布 vuex sl ...
- for循环的耗时问题
结论——用变量来缓存数组长度,效率会更高
- MVC-Cache-2.应用程序缓存(Cache:1.输出缓存[2].应用程序缓存)
2.应用数据缓存-Cache 1.引入CacheHelper.cs CacheHelper.cs文件源码在下面; 2.介绍用法: //键 string ips = "键"; //值 ...
- 软硬RAID 和 不常见的RAID
若转载请于明显处标明出处:http://www.cnblogs.com/kelamoyujuzhen/p/5561809.html 为啥子引入RAID? 存储最现实的两个问题:速度.容量 001——计 ...