数独实验报告范文

发布时间:2020-03-19

Sudoku 数独实验报告

一、 算法描述

求解Sudoku让人最容易想到的方法是穷举每个方格可能的值,如果符合条件,则得到解,不符合条件则进行回溯。通过递归的方法,显然可以得到数独的解。

我想到的简单的递归方法,是每一行从左到右,试验每一个方格可能的数字,进行递归。这种方法看似非常麻烦,实际上对于一般的数独题,速度是非常快的,思想比较简单,写出来的代码也非常简单、易懂。

算法1:简单递归方法

从第一个格开始,从1到9试验,是否满足行、列、九宫格互不相同的条件。若满足条件,则填入该数字,再试验下一个格。当一个格子出现没有数字能填的情况时,说明已经填的数字有误,回溯,再进行递归。

算法2:优化的递归算法

先遍历所有格子,统计每种格子可能出现数字的个数。每次挑选可能出现数字个数最少的格子来进行递归。

设置三维数组poss[i][j][k]来存储可能出现数字的信息。poss[i][j][0]记录i行j列的格子可能出现数字的个数,poss[i][j][k](1<=k<=9) 若poss[i][j][k]=1,表示k可能在(i,j)格出现。若poss[i][j][k]=0,表示k不可能在(i,j)格中出现。每次找poss[i][j][0]最小的格子,来进行下一个递归。

算法3:生成数独棋盘的算法

我最开始的想法是穷举法,随机生成满足行各不相同的9行,再判断9宫格、每列是否符合要求,符合条件时,随机生成停止。然而,这种算法的当然时间复杂度显然是过高。第99一步的随机生成的次数是9*9/P9=9608。随机生成一组棋盘耗时就非常大。后来,我从求解的个数的程序获得启发。算法二对于1000多组解的数独棋盘,解起来也很快。随机生成填9个方格,再用算法一的方法解出来,取第一组正确的解作为棋盘即可生成填好的棋盘。再把一定数量的格子的数字随机删除,计算解的个数。如果解唯一,就得到了棋盘。

二、数据结构

这三种算法的数据结构不是非常复杂,只是普通的数组。

算法一:数组a[i][j]

算法二:数组a[i][j]和poss[i][j][k]

算法三:数组a[i][j]和poss[i][j][k]

三、时间效率分析

算法1:这种算法在tsinsen系统上只用了15ms得到全部答案。

虽然这种算法在tsinsen系统的测试中有很好的表现,但是我试了试在几道骨灰级难度的题,发现这种算法可能会用到10秒以上的时间,并且测试数据不同,时间差异非常大。

我认为,这种算法的漏洞在于,如果开始的格子可能出现的数字非常多,递归树开始的枝会非常多。并且,我们一般做数独题,都会先挑可能出现数字个数最少的格子来填,充分利用了已知条件。然而,这种算法只按格子的行列顺序来试验,显然非常傻。于是,我想出了第二种算法。

算法2:这种算法耗时长。

非常令人失望的是,虽然它能在短时间内解出骨灰级题目,但是,和上一个算法相比,对于简单的题目,它比较耗时。在tsinsen系统中测试的时间是91ms。它的缺陷在于,每次递归都必须更新(i,j)格子所在的行、列、九宫格所有的元素。每次要求20个数的poss[i][j]。回溯同样要更新。并且求poss[i][j]的函数时间复杂度是O(n)。每一步所耗时间比上一种算法多很多。但是,总的试验的步数能显著减少。 所以,这种算法适用于数独解题的动画演示和解极难题目。

四、程序结构

五、运行结果

六、总结和反思

后来老师提高了难度,要求程序能求出多解数独题的解的个数。几千个解的数据都能迅速得出答案,但是几万个解的数据,需要很长时间,更别提几百万的数据。这两种递归的算法都有问题,优化的空间也有限,需要更强大、高效的算法。

这次Project让我不断思考,改进了最初的算法。编程是确实是一个克服困难、不断改进与超越的过程。总有新的数据摆在面前,把原来的算法打击得很惨,激励着我们研究更加先进的算法。

数独实验报告范文 相关内容:

弗兰克-赫兹实验为能级的存在提供了直接的证据,对玻尔的原子理论是一个有力支持,那么,下面是第一范文网小编给大家整理收集的弗兰克赫兹实验报告内容,供大家阅读参考。...

初中化学实验报告如何写?下面是第一范文网小编给大家整理收集的初中化学实验报告的相关模板,仅供参考。初中化学实验报告1实验名称 组装实验室制取氧气的装置实验目的 正确地组装一套实验室制取氧气的装置,并做好排水集气的准备实验器材...

本科生实验报告格式及相关要求填写说明1、 适用于本科生所有的实验报告(印制实验报告册除外);2、 专业填写为专业全称,有专业方向的用小括号标明;3、 格式要求:① 用A4纸双面打印(封面双面打印)或在A4大小纸上用蓝黑色水笔书写。...

大学物理实验报告模板实验报告一.预习报告1.简要原理2.注意事项二.实验目的三.实验器材四.实验原理五.实验内容、步骤六.实验数据记录与处理七.实验结果分析以及实验心得八.原始数据记录栏(最后一页)把实验的目的、方法、过程、结果等记录...

一、实验目的1、了解局域网的组网方式以及双绞线的两种制作规范; 2、掌握RJ-45水晶头的制作,以及网线连通性的测试。二、实验环境RJ-45水晶头若干、双绞线若干米、压线钳一把、测线仪一套。...

一、背景作业场所的合理采光与照明,对生产中的效率、卫生和安全都有重要的意义。它是工作场所设计中的重要项目,无论是天然采光还是人工照明,其主要目的都是给人们的生活和生产提供必需的视觉条件。...

一、问题的提出长期以来,我国中学外语教学效果不理想。学生从初中开始上外语课,上几 学期外语课之后就迅速地产生 了对外语课的厌烦情绪,即使研究生毕业之后, 绝大多数人也只能书面翻译和阅读本学科的外文资料,而不能 流利地与外国专...

【提出问题】(1)在前面做过了“测量小灯泡的电阻”的实验,参考它的思路,怎样测量小灯泡的电功率?(2)如果给你额定电压分别为2.5V和3.8V的小灯泡各一只,你能测出它们的电功率吗?(3)小灯泡上面如果标有额定功率,所标额定功率与通过P=UI测...

查看更多>>

android 数独实训报告,数独实验报告范文相关推荐

  1. java坦克大战 实训报告_程序设计实训坦克大战实验报告

    <程序设计实训坦克大战实验报告>由会员分享,可在线阅读,更多相关<程序设计实训坦克大战实验报告(12页珍藏版)>请在金锄头文库上搜索. 1. 程序设计实训报告坦克大战专业班级: ...

  2. 计算机病毒实训,2021计算机病毒实验报告

    <2021计算机病毒实验报告>由会员分享,可在线阅读,更多相关<2021计算机病毒实验报告(5页珍藏版)>请在人人文库网上搜索. 1.计算机病毒实验报告计算机病毒实验报告 说 ...

  3. 计算机网络实训简介,计算机网络实验报告介绍.doc

    学 生 实 验 报 告 (理工类) 课程名称:计算机网络与通信 1305102046 学生姓名: 桑 倩 所属院部:电子信息工程学院 指导教师: 陈 存 宝 20 15 --20 16 学年 第 1 ...

  4. android实训报告日记,android目实训报告.doc

    android目实训报告 Android项目实训报告 学号 201033201 姓名 ***项目 名称 记事本项 目 介 绍 我的项目分为心情日志,备忘 录和日记,有记录和查询的功能项 目 分 析 我 ...

  5. Android星座查询实验报告,科技实验报告

    科技实验报告 一.定义与作用实验报告,就是在某项科研活动或专业学习中,实验者把实验的目的.方法.步骤.结果等,用简洁的语言写成书面报告.实验报告必须在科学实验的基础上进行.成功的或失败的实验结果的记载 ...

  6. c语言秒表实训报告实验结果,实验报告范文范本 -实习报告

    实验报告范文范本 -实习报告 实习报告 时间:2019-01-01 [www.unjs.com - 实习报告] 物理探究实验:影响摩擦力大小的因素 探究准备 技能准备: 弹簧测力计,长木板,棉布,毛巾 ...

  7. c语言递归算法实验报告,递归算法实验报告.docx

    递归算法实验报告 递归算法实验报告 篇一:递归算法的设计和实现的实验报告 班级学号 姓名 实验组别 试验日期 室温 报告日期成绩 报告内容:(目的和要求.原理.步骤.数据.计算.小结等) 实验名称:递 ...

  8. linux电子数码相册实验报告,Linux实验报告.doc

    Linux实验报告Linux实验报告 实 验 报 告 课程名称 Linux操作系统安装配置和管理 年级班级 学号姓名 任课教师 康长青 目录 实验一. Linux常用命令的使用3 一.实验目的3 二. ...

  9. c语言Dvv实验报告,电渗实验报告

    篇一:实验35电渗 实验35 电渗 一.目的 ①用电渗法测定SiO2对水的?电势 ②观察电渗现象,了解电渗法实验技术概要. 二.基本原理 电渗是胶体常见的电动现象的一种.早在1809年,就观察到在电场 ...

  10. 什么是计算机应用上机报告,计算机应用实验报告样本.doc

    计算机应用实验报告样本 成绩 实验报告 课程名称:计算机在道路运输管理中的应用 学 院:交通运输专 业:交通运输 班 级: 学生姓名: 学 号: 指导教师: 朱 灿 ====2010 /2011学年第 ...

最新文章

  1. 解决SSH远程执行命令找不到环境变量的问题
  2. tensorflow.python.framework.errors_impl.DataLossError:
  3. 项目: 双人反弹球游戏
  4. 【python 8】python 装饰器
  5. phpMyAdmin密码设置
  6. Python基础总结之常用内置方法总结
  7. JQuery Datatables editor进行增删改查操作(二)
  8. symfony app dev.php,Symfony 2:404未找到当tryes打开/app_dev.php时出错
  9. 小明用计算机算出58十35,人教版三年级数学下册第三四单元测试卷.docx
  10. java json 替换属性值_替换JSONObject某个对象的值
  11. 用ICC编译MP3编码器LAME
  12. Tinkpad T480设置U盘启动
  13. html5图片和两行文字垂直居中显示,何如让文字跟图片垂直居中对齐
  14. sql UPDATE的时候可以使用join吗
  15. linux mysql5.7.11_Centos7.2 Systemd 方式编译 Mysql5.7.11
  16. 华为静态NAT、动态NAT、NAPT、Easy NAT配置实例
  17. Markdown极简教程
  18. php模拟登陆正方教务系统(2018年)
  19. 二叉树的基本概念和计算公式
  20. elasticsearch地理位置查询

热门文章

  1. cmos和ttl_CMOS与TTL电路的详细对比区别
  2. Clickhouse 实现row_number、dense_rank
  3. [读书笔记]普林斯顿微积分读本(修订版)-未完工
  4. matlab多目标遗传算法工具箱,运用MATLAB遗传算法工具箱求解非线性多目标优化问题,...
  5. 2021 年百度之星·程序设计大赛 - 初赛三
  6. 操作系统课程设计--银行家算法的模拟实现
  7. 常用DOS命令(必会基础知识)
  8. Mellanox网卡不能分配VF解决方法
  9. 活著就为改变世界---史蒂夫.乔布斯…
  10. python万年历代码带解释_带闹钟的单片机万年历代码说明(详细注释)