python自带tkinter库实现棋盘覆盖图形界面


Posted in Python onJuly 17, 2019

python实现棋盘覆盖图形界面,供大家参考,具体内容如下

一、解决方案和关键代码

工具: python tkinter库

问题描述:

  在一个2^k×2^k个方格组成的棋盘中,若有一个方格与其他方格不同,则称该方格为一特殊方格,且称该棋盘为一个特殊棋盘.显然特殊方格在棋盘上出现的位置有4^k种情形.因而对任何k≥0,有4^k种不同的特殊棋盘。
  在棋盘覆盖问题中,要用下图中 4 中不同形态的 L 型骨牌覆盖一个给定的特殊棋牌上除特殊方格以外的所有方格,且任何 2 个 L 型骨牌不得重叠覆盖。易知,在任何一个 2^k × 2^k 的棋盘中,用到的 L 型骨牌个数恰为 (4^k-1)/3 。

python自带tkinter库实现棋盘覆盖图形界面

解决方法:递归与分治法

  用分治策略,可以设计解棋盘问题的一个简捷的算法。
  当 k>0 时,将 2^k * 2^k 棋盘分割为 4 个 2^(k-1) * 2^(k-1) 子棋盘;
  特殊方格必位于 4 个较小子棋盘之一中,其余 3 个子棋盘中无特殊方格。为了将这 3 个无特殊方格的子棋盘转化为特殊棋盘,我们可以用一个 L 型骨牌覆盖这 3 个较小的棋盘的汇合处,如下图所示,这 3 个子棋盘上被 L 型骨牌覆盖的方格就成为该棋盘上的特殊方格,从而将原问题化为 4 个较小规模的棋盘覆盖问题。递归的使用这种分割,直至棋盘简化为 1x1 棋盘。

python自带tkinter库实现棋盘覆盖图形界面

算法关键代码

def chessBoard(tr,tc,dr,dc,size):
 global tile
 global board
 if (size==1):
  return 0
 tile+=1
 t=tile
 s=size//2
 #the upper left corner
 if (dr<tr+s and dc<tc+s):
  chessBoard(tr,tc,dr,dc,s)
 else:
  board[tr+s-1,tc+s-1]=t
  chessBoard(tr,tc,tr+s-1,tc+s-1,s)
 #the upper right corner
 if (dr<tr+s and dc>=tc+s):
  chessBoard(tr,tc+s,dr,dc,s)
 else:
  board[tr+s-1,tc+s]=t
  chessBoard(tr,tc+s,tr+s-1,tc+s,s)
 #the lower left corner
 if (dr>=tr+s and dc<tc+s):
  chessBoard(tr+s,tc,dr,dc,s)
 else:
  board[tr+s,tc+s-1]=t
  chessBoard(tr+s,tc,tr+s,tc+s-1,s)
 #the lower right corner
 if (dr>=tr+s and dc>=tc+s):
  chessBoard(tr+s,tc+s,dr,dc,s)
 else:
  board[tr+s,tc+s]=t
  chessBoard(tr+s,tc+s,tr+s,tc+s,s)

画棋盘关键代码:

def drawboard(canvas1,board,colors,startx=50,starty=50,cellwidth=50):
 width=2*startx+len(board)*cellwidth
 height=2*starty+len(board)*cellwidth
 canvas1.config(width=width,height=height)#布置画布
 for i in range(len(board)):
  for j in range(len(board)):
   index=board[i][j]
   if index== 0:    
    color='white'#特殊方格显示为白色
   else:
    color=colors[6*index]#为了间隔开颜色
   cellx=startx+i*50
  celly=starty+j*50  
  canvas1.create_rectangle(cellx,celly,cellx+cellwidth,celly+cellwidth,fill=color,outline="black")#画方格
 canvas1.update()

二、数据测试

特殊方格坐标为(1,1),棋盘大小为(2^2*2^2)

python自带tkinter库实现棋盘覆盖图形界面

特殊方格坐标为(2,2),棋盘大小为(2^3*2^3)

 python自带tkinter库实现棋盘覆盖图形界面

完整代码下载链接点这里

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
python切换hosts文件代码示例
Dec 31 Python
python异常和文件处理机制详解
Jul 19 Python
将pandas.dataframe的数据写入到文件中的方法
Dec 07 Python
python requests 库请求带有文件参数的接口实例
Jan 03 Python
Gauss-Seidel迭代算法的Python实现详解
Jun 29 Python
python 计算数据偏差和峰度的方法
Jun 29 Python
Django用户认证系统 组与权限解析
Aug 02 Python
Django ORM 查询管理器源码解析
Aug 05 Python
Python 中的 import 机制之实现远程导入模块
Oct 29 Python
利用python+ffmpeg合并B站视频及格式转换的实例代码
Nov 24 Python
Python3.8官网文档之类的基础语法阅读
Sep 04 Python
python程序的组织结构详解
Dec 06 Python
python递归法解决棋盘分割问题
Jul 17 #Python
Django-Model数据库操作(增删改查、连表结构)详解
Jul 17 #Python
python通过TimedRotatingFileHandler按时间切割日志
Jul 17 #Python
python递归法实现简易连连看小游戏
Mar 25 #Python
django2笔记之路由path语法的实现
Jul 17 #Python
Django之创建引擎索引报错及解决详解
Jul 17 #Python
python实现连连看辅助之图像识别延伸
Jul 17 #Python
You might like
利用js调用后台php进行数据处理原码
2006/10/09 PHP
一些PHP写的小东西
2006/12/06 PHP
关于PHP递归算法和应用方法介绍
2013/04/15 PHP
分享14个很酷的jQuery导航菜单插件
2011/04/25 Javascript
深入理解JavaScript系列(15) 函数(Functions)
2012/04/12 Javascript
js弹窗返回值详解(window.open方式)
2014/01/11 Javascript
jquery xMarquee实现文字水平无缝滚动效果
2014/04/29 Javascript
JS闭包可被利用的常见场景小结
2017/04/09 Javascript
vue使用xe-utils函数库的具体方法
2018/03/06 Javascript
Vue中的字符串模板的使用
2018/05/17 Javascript
在vue中获取token,并将token写进header的方法
2018/09/26 Javascript
vue项目每30秒刷新1次接口的实现方法
2018/12/04 Javascript
简单了解微信小程序的目录结构
2019/07/01 Javascript
layui table单元格事件修改值的方法
2019/09/24 Javascript
微信小程序 textarea 层级过高问题简单解决方案
2019/10/14 Javascript
javascript(基于jQuery)实现鼠标获取选中的文字示例【测试可用】
2019/10/26 jQuery
JavaScript经典案例之简易计算器
2020/08/24 Javascript
Bootstrap告警框(alert)实现弹出效果和短暂显示后上浮消失的示例代码
2020/08/27 Javascript
老生常谈python之鸭子类和多态
2017/06/13 Python
python中利用Future对象回调别的函数示例代码
2017/09/07 Python
Python基于lxml模块解析html获取页面内所有叶子节点xpath路径功能示例
2018/05/16 Python
python中几种自动微分库解析
2019/08/29 Python
python验证码图片处理(二值化)
2019/11/01 Python
Python 实现一行输入多个数字(用空格隔开)
2020/04/29 Python
Python闭包及装饰器运行原理解析
2020/06/17 Python
python如何停止递归
2020/09/09 Python
Python 虚拟环境工作原理解析
2020/12/24 Python
一款纯css3实现的动画加载导航
2014/10/08 HTML / CSS
菲律宾酒店预订网站:Hotels.com菲律宾
2017/07/12 全球购物
List、Map、Set三个接口,存取元素时,各有什么特点?
2015/09/27 面试题
抽象类和接口的区别
2012/09/19 面试题
2014年安全生产目标责任书
2014/07/23 职场文书
小学生关于梦想的演讲稿
2014/08/22 职场文书
工商局副局长个人对照检查材料
2014/09/25 职场文书
成功的商业计划书这样写才最靠谱
2019/07/12 职场文书
利用 SQL Server 过滤索引提高查询语句的性能分析
2021/07/15 SQL Server