python自带自带tkinter库实现棋盘覆盖图形界面库实现棋盘覆盖图形界面
主要为大家详细介绍了python自带tkinter库实现棋盘覆盖图形界面,具有一定的参考价值,感兴趣的小伙伴们可
以参考一下
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 。
解决方法:解决方法:递归与分治法
用分治策略,可以设计解棋盘问题的一个简捷的算法。
当 k>0 时,将 2^k * 2^k 棋盘分割为 4 个 2^(k-1) * 2^(k-1) 子棋盘;
特殊方格必位于 4 个较小子棋盘之一中,其余 3 个子棋盘中无特殊方格。为了将这 3 个无特殊方格的子棋盘转化为特殊
棋盘,我们可以用一个 L 型骨牌覆盖这 3 个较小的棋盘的汇合处,如下图所示,这 3 个子棋盘上被 L 型骨牌覆盖的方格就成
为该棋盘上的特殊方格,从而将原问题化为 4 个较小规模的棋盘覆盖问题。递归的使用这种分割,直至棋盘简化为 1x1 棋
盘。
算法关键代码算法关键代码
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