一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

腳本之家,腳本語言編程技術及教程分享平臺!
分類導航

Python|VBS|Ruby|Lua|perl|VBA|Golang|PowerShell|Erlang|autoit|Dos|bat|

服務器之家 - 腳本之家 - Python - Python3解決棋盤覆蓋問題的方法示例

Python3解決棋盤覆蓋問題的方法示例

2020-12-22 00:54littlethunder Python

這篇文章主要介紹了Python3解決棋盤覆蓋問題的方法,簡單描述了棋盤覆蓋問題的概念、原理及Python相關操作技巧,需要的朋友可以參考下

本文實例講述了Python3解決棋盤覆蓋問題的方法。分享給大家供大家參考,具體如下:

問題描述:

在2^k*2^k個方格組成的棋盤中,有一個方格被占用,用下圖的4種L型骨牌覆蓋所有棋盤上的其余所有方格,不能重疊。

Python3解決棋盤覆蓋問題的方法示例

代碼如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
def chess(tr,tc,pr,pc,size):
  global mark
  global table
  mark+=1
  count=mark
  if size==1:
    return
  half=size//2
  if pr<tr+half and pc<tc+half:
    chess(tr,tc,pr,pc,half)
  else:
    table[tr+half-1][tc+half-1]=count
    chess(tr,tc,tr+half-1,tc+half-1,half)
  if pr<tr+half and pc>=tc+half:
    chess(tr,tc+half,pr,pc,half)
  else:
    table[tr+half-1][tc+half]=count
    chess(tr,tc+half,tr+half-1,tc+half,half)
  if pr>=tr+half and pc<tc+half:
    chess(tr+half,tc,pr,pc,half)
  else:
    table[tr+half][tc+half-1]=count
    chess(tr+half,tc,tr+half,tc+half-1,half)
  if pr>=tr+half and pc>=tc+half:
    chess(tr+half,tc+half,pr,pc,half)
  else:
    table[tr+half][tc+half]=count
    chess(tr+half,tc+half,tr+half,tc+half,half)
def show(table):
  n=len(table)
  for i in range(n):
    for j in range(n):
      print(table[i][j],end=' ')
    print('')
mark=0
n=8
table=[[-1 for x in range(n)] for y in range(n)]
chess(0,0,2,2,n)
show(table)

n是棋盤寬度,必須是2^k,本例中n=8,特殊格子在(2,2)位置,如下圖所示:

Python3解決棋盤覆蓋問題的方法示例

采用分治法每次把棋盤分成4份,如果特殊格子在這個小棋盤中則繼續分成4份,如果不在這個小棋盤中就把該小棋盤中靠近中央的那個格子置位,表示L型骨牌的1/3占據此處,每一次遞歸都會遍歷查詢4個小棋盤,三個不含有特殊格子的棋盤置位的3個格子正好在大棋盤中央構成一個完整的L型骨牌,依次類推,找到全部覆蓋方法。運行結果如下:

Python3解決棋盤覆蓋問題的方法示例

希望本文所述對大家Python程序設計有所幫助。

原文鏈接:http://blog.csdn.net/littlethunder/article/details/25288969

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 国产在线成人精品 | 99视频久久 | 成年性午夜免费视频网站不卡 | 久久偷拍国2017 | 小寡妇水真多好紧 | 日本videosdesexo乱| 国内精品99 | 色cccwww在线播放 | 女黑人尺寸bbb | 婷婷综合在线 | 国产人人草| 3p文两男一女办公室高h | 翁熄性放纵交换300章 | 国产一区二区视频在线观看 | 日本三级s级在线播放 | 欧美日韩一区不卡 | 双性肉文高h | 8x8x极品国产在线 | 欧美激情影音先锋 | 精品AV亚洲乱码一区二区 | 99精品国产高清一区二区三区香蕉 | 国产午夜免费 | 成人动漫在线免费看 | 国产精品视频播放 | 色碰视频 | 人人擦 | 91制片厂制作果冻传媒破解 | 2022av小四郎的最新地址 | 手机在线观看伦理片 | 狠狠燥| 边摸边吃奶玩乳尖视频 | 91混血大战上海双胞胎 | 亚洲男人天堂网址 | 日本 片 成人 在线 日b视频免费 | 亚洲国产成人久久99精品 | bl双性肉文 | 俄罗斯一级在线播放 | 红色一片在线影视 | 亚洲男人的天堂网 | 久久成人伊人欧洲精品AV | 97影院秋霞国产精品 |