python棋盘覆盖_python版棋盘覆盖问题核心代码

这是一个使用Python编写的棋盘覆盖问题的解决方案。通过递归函数`chessBoard`,根据棋盘的规格和特殊方格的位置,用L型骨牌进行覆盖。函数会根据特殊方格是否位于当前子棋盘内,决定骨牌的放置位置并继续覆盖剩余部分。
摘要由CSDN通过智能技术生成

tile = 0#L型骨牌号

t = 0

Board = []

#tr:棋盘左上角方格的行号

#tc:棋盘左上角方格的列号

#dr:特殊方格的行号

#dc:特殊方格的列号

#size:棋盘的规格

def chessBoard(tr,tc,dr,dc,size):

if(size == 1):

return

t = tile + 1

s = size /2

#覆盖棋牌左上角子棋盘

if(dr < tr + s and dc < tc + s):

#特殊方格在此棋盘中

chessBoard(tr,tc,dr,dc,s)

else:

#用t号L型骨牌覆盖右下角

Board[tr + s -1][tc + s -1] = t

#覆盖剩余棋盘

chessBoard(tr,tc,tr+s-1,tc+s-1,s)

#覆盖右上角子棋盘

if(dr < tr + s and dc >= tc + s):

#特殊方格在此棋盘中

chessBoard(tr,tc+s,dr,dc,s)

else:

#用t号L型骨牌覆盖左下角

Board[tr+s-1][tc+s] = t

#覆盖剩余棋盘

chessBoard(tr,tc+s,tr+s-1,tc+s)

#覆盖左下角棋盘

if(dr >= tr +s and dc < tc+s):

#特殊方格在此棋盘中

chessBoard(tr+s,tc,dr,dc,s)

else:

#用t号L型骨牌覆盖右上角

Board[tr+s][tc+s-1] = t

#覆盖剩余棋盘

chessBoard(tr+s,tc,tr+s,tc+s-1)

#覆盖右下角棋盘

if(dr >= tr + s and dc >= tc + s):

#特殊方格在此棋盘中

chessBoard(tr+s,tc+s,dr,dc,s)

else:

#用t号L型骨牌覆盖右下角

Board[tr+s,tc+s] = t

#覆盖剩余棋盘

chessBoard(tr+s,tc+s,tr+s,tc+s,s)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值