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系列之数据处理编程实例(一)
May 22 Python
在Python的Tornado框架中实现简单的在线代理的教程
May 02 Python
python实现中文转换url编码的方法
Jun 14 Python
JSONLINT:python的json数据验证库实例解析
Nov 28 Python
一篇文章快速了解Python的GIL
Jan 12 Python
python字符串的方法与操作大全
Jan 30 Python
Tensorflow之构建自己的图片数据集TFrecords的方法
Feb 07 Python
Python3单行定义多个变量或赋值方法
Jul 12 Python
Opencv+Python 色彩通道拆分及合并的示例
Dec 08 Python
pandas读取csv文件,分隔符参数sep的实例
Dec 12 Python
python之pexpect实现自动交互的例子
Jul 25 Python
基于Python实现全自动下载抖音视频
Nov 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
PHP的面向对象编程
2006/10/09 PHP
php对gzip文件或者字符串解压实例参考
2008/07/25 PHP
基于PHPExcel的常用方法总结
2013/06/13 PHP
PHP的MVC模式实现原理分析(一相简单的MVC框架范例)
2014/04/29 PHP
PHP内置过滤器FILTER使用实例
2014/06/25 PHP
PHP5.5新特性之yield理解与用法实例分析
2019/01/11 PHP
javascript 数组排序函数
2009/08/20 Javascript
通过继承IHttpHandle实现JS插件的组织与管理
2010/07/13 Javascript
jQuery+ajax实现顶一下,踩一下效果
2010/07/17 Javascript
js实现刷新iframe的方法汇总
2015/04/27 Javascript
javascript带回调函数的异步脚本载入方法实例分析
2015/07/02 Javascript
基于javascript实现随机颜色变化效果
2016/01/14 Javascript
利用Angularjs和bootstrap实现购物车功能
2016/08/31 Javascript
AngularJS 面试题集锦
2016/09/06 Javascript
jQuery 移动端拖拽(模块化开发,触摸事件,webpack)
2016/10/28 Javascript
基于JavaScript实现多级菜单效果
2017/07/25 Javascript
vue中axios解决跨域问题和拦截器的使用方法
2018/03/07 Javascript
JS与CSS3实现图片响应鼠标移动放大效果示例
2018/05/04 Javascript
深入浅析vue-cli@3.0 使用及配置说明
2019/05/08 Javascript
javascript+css实现俄罗斯方块小游戏
2020/06/28 Javascript
JS倒计时两种实现方式代码实例
2020/07/27 Javascript
js对象属性名驼峰式转下划线的实例代码
2020/09/17 Javascript
详解vue实现坐标拾取器功能示例
2020/11/18 Vue.js
[04:49]期待西雅图之战 2016国际邀请赛中国区预选赛WINGS战队赛后采访
2016/06/29 DOTA
Python学习笔记之if语句的使用示例
2017/10/23 Python
python 计算数组中每个数字出现多少次--“Bucket”桶的思想
2017/12/19 Python
用python爬取租房网站信息的代码
2018/12/14 Python
Python Django框架实现应用添加logging日志操作示例
2019/05/17 Python
浅谈Python 参数与变量
2020/06/20 Python
基于python获取本地时间并转换时间戳和日期格式
2020/10/27 Python
详解Python中openpyxl模块基本用法
2021/02/23 Python
ZWILLING双立人法国网上商店:德国刀具锅具厨具品牌
2019/08/28 全球购物
橄榄树药房:OLIVEDA
2019/09/01 全球购物
Linux机考试题
2015/10/16 面试题
职业生涯规划书的格式
2013/12/29 职场文书
集体婚礼证婚词
2014/01/13 职场文书