代码语言
.
CSharp
.
JS
Java
Asp.Net
C
MSSQL
PHP
Css
PLSQL
Python
Shell
EBS
ASP
Perl
ObjC
VB.Net
VBS
MYSQL
GO
Delphi
AS
DB2
Domino
Rails
ActionScript
Scala
代码分类
文件
系统
字符串
数据库
网络相关
图形/GUI
多媒体
算法
游戏
Jquery
Extjs
Android
HTML5
菜单
网页交互
WinForm
控件
企业应用
安全与加密
脚本/批处理
开放平台
其它
【
Python
】
n皇后问题的优化解法
作者:
刘地
/ 发布于
2012/11/19
/
711
num=8 class Queen(object): def __init__(self,n): self.lct= n self.prs=-1 self.cdt=[1 for i in range(num)] def Count(q): s=0 for i in range(num): if q.cdt[i]>0:s+=1 return s def FindIt(q): u=q.prs+1; while u<num and q.cdt[u]<=0:u+=1 if u<num: q.prs=u return True return False def Settle(q,n): x=q[n].lct y=q[n].prs for i in range(n+1,num,1): p=q[i].cdt p[y]-=1 a=q[i].lct-x b=y-a if b>=0 and b<num:p[b]-=1 b=y+a if b>=0 and b<num:p[b]-=1 def Pickup(q,n): x=q[n].lct y=q[n].prs for i in range(n+1,num,1): p=q[i].cdt p[y]+=1 a=q[i].lct-x b=y-a if b>=0 and b<num:p[b]+=1 b=y+a if b>=0 and b<num:p[b]+=1 def Select(q,n): j,k=0,num+1 for i in range(n,num): t=Count(q[i]) if k>t:j,k=i,t if j!=n:q[n],q[j]=q[j],q[n] def ShowIt(q): for i in range(num): for j in range(num): if q[j].lct==i: for k in range(num): if q[j].prs==k: print '*', else: print '-', print '' print '' def Locate1(): q=[Queen(i) for i in range(num)] i=0 j=0 while 1: if q[i].prs<0: Select(q,i) else: Pickup(q,i) if FindIt(q[i]): if i<num-1: Settle(q,i) i+=1 else: j+=1 yield j #ShowIt(q) else: q[i].prs=-1 i-=1 if i<0:break def Locate2(): q=[Queen(i) for i in range(num)] i=0 j=0 while 1: if q[i].prs>=0:Pickup(q,i) if FindIt(q[i]): if i<num-1: Settle(q,i) i+=1 else: j+=1 yield j #ShowIt(q) else: q[i].prs=-1 i-=1 if i<0:break if __name__=='__main__': q=[Queen(i) for i in range(num)] import time t=time.time() Locate1().next() print 'once cost %.6f'%(time.time()-t) print '-----------------' t=time.time() Locate2().next() print 'once cost %.6f'%(time.time()-t)
试试其它关键字
n皇后
同语言下
.
比较两个图片的相似度
.
过urllib2获取带有中文参数的url内容
.
不下载获取远程图片的宽度和高度及文件大小
.
通过qrcode库生成二维码
.
通过httplib发送GET和POST请求
.
Django下解决小文件下载
.
遍历windows的所有窗口并输出窗口标题
.
根据窗口标题调用窗口
.
python 抓取搜狗指定公众号
.
pandas读取指定列
可能有用的
.
C#实现的html内容截取
.
List 切割成几份 工具类
.
SQL查询 多列合并成一行用逗号隔开
.
一行一行读取txt的内容
.
C#动态修改文件夹名称(FSO实现,不移动文件)
.
c# 移动文件或文件夹
.
c#图片添加水印
.
Java PDF转换成图片并输出给前台展示
.
网站后台修改图片尺寸代码
.
处理大图片在缩略图时的展示
刘地
贡献的其它代码
(
3
)
.
动态哈夫曼压缩算法
.
右递归的超简单八皇后解决
.
n皇后问题的优化解法
Copyright © 2004 - 2024 dezai.cn. All Rights Reserved
站长博客
粤ICP备13059550号-3