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

腳本之家,腳本語言編程技術(shù)及教程分享平臺!
分類導(dǎo)航

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

服務(wù)器之家 - 腳本之家 - Python - python基于右遞歸解決八皇后問題的方法

python基于右遞歸解決八皇后問題的方法

2020-07-07 10:10小蘿莉 Python

這篇文章主要介紹了python基于右遞歸解決八皇后問題的方法,實例分析了右遞歸算法的相關(guān)使用技巧,需要的朋友可以參考下

本文實例講述了python基于右遞歸解決八皇后問題的方法。分享給大家供大家參考。具體分析如下:

凡是線性回溯都可以歸結(jié)為右遞歸的形式,也即是二叉樹,因此對于只要求一個解的問題,采用右遞歸實現(xiàn)的程序要比回溯法要優(yōu)美的多。

?
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
def Test(queen,n):
 '''這個就不用說了吧,就是檢驗第n(下標,0-7)行皇后的位置是否合理'''
 q=queen[n]
 for i in xrange(n):
  if queen[i]==q or queen[i]-q==n-i or queen[i]-q==i-n:return False
 return True
def Settle(queen,n):
 '''這個負責(zé)安置第n(下標,0-7)行皇后,每次調(diào)用,皇后都至少會移動一步'''
 queen[n]+=1
 while queen[n]<8 and not Test(queen,n):queen[n]+=1
 return queen[n]<8
def Solve(queen,n):
 '''這個負責(zé)解決第n(下標,0-7)行皇后的安置以及隨后所有皇后的安置'''
 if n==8:#安置完所有皇后了,故輸出列表
  print queen
  return True#如果設(shè)為假,則會嘗試所有的安置方案
 else:
  queen[n]=-1#初始化第n行皇后的起始位置(起始位置-1,可安置在0-7)
  while Settle(queen,n):#如果成功安置皇后
   if Solve(queen,n+1):#安置其余皇后
    return True#成功安置,返回真
 return False#失敗,返回假
if __name__=='__main__':
 Solve([-1 for i in range(8)],0)#列表的值可以隨便設(shè)置,因為會初始化
#雖然我們沒有進行回溯,但事實上,我們每一個參數(shù)相同的Solve函數(shù)都嘗試了多次
#輸出:[0, 4, 7, 5, 2, 6, 1, 3]
#比回溯法容易多了吧

希望本文所述對大家的Python程序設(shè)計有所幫助。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 3黑人巨大vs北岛玲 3d肉浦团在线观看 3d动漫免费 | 欧美在线一级视频 | 2019年国产不卡在线刷新 | 欧美1区| 国产盗摄wc女厕所 | heyzo在线观看| 成人福利在线观看 | 校园纯肉H教室第一次 | 亚裔aⅴ艳星katsuni | 香蕉久久ac一区二区三区 | 变态 另类 国产 亚洲 | 亚洲欧美久久一区二区 | 色老头oldmoneyvideos | www一区| 精品一区二区三区高清免费不卡 | 日本网络视频www色高清免费 | 好大好长好紧爽免费 | 国产精品久久久久不卡绿巨人 | 成人毛片高清视频观看 | 高清色黄毛片一级毛片 | kuaibo成人播放器 | 草草精品视频 | 成年女人毛片免费观看中文w | 亚洲精品m在线观看 | 毛片免费网站 | 美女的让男人桶爽免费看 | a韩剧| 无码AV精品一区二区三区 | 91香蕉嫩草| 五月色综合婷婷综合俺来也 | 女同全黄h全肉动漫 | www.爱操| 91高清免费国产自产 | 亚洲AV无码国产精品色在线看 | 日本免费久久久久久久网站 | 日韩欧美中文在线 | 国产大片线上免费观看 | 国产福利在线观看永久视频 | 欧美大片一区 | 韩国禁片在线观看久 | 二次元美女挤奶漫画 |