• 首页
  • 资料下载
  • IT书店
  • 论坛交流
  • 最新文章
  • 更多
    • 壁纸大全
    • 天气预报
    • QQ群联盟
    • 网址导航
    • 团队博客
    • 联系我们
设软件水平考试网为首页 | 注册 | 登陆

  • 财会类
    • 财会类
    • 会计从业
    • 中级会计
    • 经济师
    • 注册税务师
    • 银行从业
    • 内审师
    • 资产评估
    • 统计师
    • 审计师
    • 更多>>
  • 建筑类
    • 建筑类
    • 一级建造师
    • 二级建造师
    • 造价工程师
    • 咨询工程师
    • 监理工程师
    • 房地产估价
    • 结构工程师
    • 注册建筑师
    • 土地估价师
    • 更多>>
  • 职业资格
    • 职业资格
    • 证券从业
    • 期货从业
    • 司法考试
    • 教师资格
    • 秘书资格
    • 保险从业
    • 导游资格
    • 人力资源
    • 电子商务
    • 更多>>
  • 公务员
    • 公务员
    • 行测
    • 申论
    • 面试
    • 真题大全
    • 公考心得
    • 公考辅导
    • 招警
    • 更多>>
  • 外贸类
    • 外贸类
    • 报关员
    • 报检员
    • 国际商务师
    • 单证员
    • 货运代理
    • 外销员
    • 更多>>
  • 医药类
    • 医药类
    • 执业护士
    • 中药师
    • 西药师
    • 临床医师
    • 临床助理
    • 中医医师
    • 口腔医师
    • 公共卫生
    • 更多>>
  • 外语类
    • 外语类
    • CET4
    • CET6
    • 职称英语
    • 托福
    • 雅思
    • BEC
    • 金融英语
    • 小语种
    • 更多>>
  • 学历考试
    • 学历考试
    • 高考
    • 成考
    • 考研
    • 自考
    • 中考
    • 考博
    • 在职硕士
    • 更多>>
  • 计算机类
    • 计算机类
    • 计算机二级
    • 计算机等级
    • 软件水平
    • 微软认证
    • 思科认证
    • 更多>>
  • 全部分类
    • 全部分类
    • 所有考试
    • 更多>>

 下载|书店 | 论坛|(QQ群:32090693)
  • 优易学品牌推荐:
  • 软件资料下载
  • 软件图书购买
软考首页
考试书店 | 资讯 | 报考指南 | 初级 | 中级 | 高级 | 备考辅导 | 历年真题 | 模拟题 | IT技术 | 专业英语 | 心得 | 资料中心 | 论坛交流
您现在的位置: 优易学 >> 计算机 >> 软件水平考试 >> 初级资格 >> 程序员 >> 正文
 
站内搜索:
数据结构算法中写了一个八皇后解法
来源:优易学  2011-12-26 11:22:48   【优易学:中国教育考试门户网】   资料下载   IT书店
  先用最笨的穷举法求解,有空再研究更好的解法:
  # -*- coding: gb2312 -*-
  size = 8 # 棋盘大小
  EMPTY = "O" # 空位
  QUEEN = "X" # 皇后
  # 查看棋盘的信息
  def show_board(cols):
  for i in range(1, size + 1):
  for j in range(1, size + 1):
  if j == cols[i]:
  print QUEEN,
  else:
  print EMPTY,
  print "\n",
  # 检测棋盘上皇后摆法是否合法
  # return:
  # True(不冲突), False(有冲突)
  def check_board(cols):
  for i in range(1, size):
  for j in range(i + 1, size + 1):
  if (j - i) == abs(cols[j] - cols[i]):
  return False
  return True
  solve_count = 0
  for a in range(1, size + 1):
  for b in range(1, size + 1):
  for c in range(1, size + 1):
  for d in range(1, size + 1):
  for e in range(1, size + 1):
  for f in range(1, size + 1):
  for g in range(1, size + 1):
  for h in range(1, size + 1):
  if a <> b and a <> c and a <> d and a <> e and a <> f and a <> g and a <> h and b <> c and b <> d and b <> e and b <> f and b <> g and b <> h and c <> d and c <> e and c <> f and c <> g and c <> h and d <> e and d <> f and d <> g and d <> h and e <> f and e <> g and e <> h and f <> g and f <> h and g <> h:
  cols = [0,a,b,c,d,e,f,g,h]
  if check_board(cols):
  solve_count += 1
  show_board(cols)
  print "\n",
  print "found %i solves." % solve_count
  posted on 2006-01-08 16:40 木野狐(Neil Chen) 阅读(541) 评论(1) 编辑 收藏 所属分类: 编程思考 、Python
  Feedback
  #1楼 [楼主] 2006-01-13 00:43 木野狐
  参考 All Start From A Game 改进了程序,速度提高了很多,并且能计算 n 皇后问题了:
  # -*- coding: gb2312 -*-
  size = 8 # 棋盘大小
  EMPTY = "O" # 空位
  QUEEN = "X" # 皇后
  # 查看棋盘的信息
  def show_board(cols):
  for i in range(size):
  for j in range(size):
  if j == int(cols[i]) - 1:
  print QUEEN,
  else:
  print EMPTY,
  print "\n",
  # 检测棋盘上皇后摆法是否合法
  # return:
  # True(不冲突), False(有冲突)
  def check_board(cols):
  for i in range(size - 1):
  for j in range(i + 1, size):
  if j - i == abs(int(cols[j]) - int(cols[i])):
  return False
  return True
  # 得到全排列
  def permute(seq):
  seqn = [ seq.pop() ]
  while seq:
  newseq = []
  new = seq.pop()
  #print "seq:",seq,’seqn’, seqn ,’new’, new
  for i in range(len(seqn)):
  item = seqn[i]
  for j in range(len(item)+1):
  newseq.append(’’.join([item[:j],new,item[j:]]))
  seqn = newseq
  #print ’newseq’,newseq
  return seqn
  if __name__ == "__main__":
  solve_count = 0
  numbers = ’’.join([str(i) for i in range(1, size + 1)])
  for x in permute(list(numbers)):
  y = list(x)
  if check_board(y):
  solve_count += 1
  show_board(y)
  print "\n",
  print "found %i solves." % solve_count

责任编辑:小草

  • 上一个文章: 算法分析基础学习
  • 下一个文章: 关键字过滤算法
文章搜索:
 相关文章
2009年11月软件水平考试试题:程序员(下午)
2009年11月软件水平考试试题:程序员(上午)
如何衡量程序员的工作效率
程序员应避免的十个糟糕行为
程序员:JTabbedPane刷新Jpanel面板的遍历
程序员:javaAES算法
程序员:快速排序算法Python
资讯推荐
热点资讯
考试资讯
初级辅导
  • 全国各省软考办的地址及联系方式
  • 江西2007年11月软件水平考试成绩公布查询开始
  • 山东2007年11月软件水平考试成绩公布查询开始
  • 新疆2007年11月软件水平考试成绩公布查询开始
  • 湖北省2008年软件水平考试报名预计2月下旬开始
  • 软考、职称、职称资格的解读与三者之间的联系
  • 2009年下半年软件水平考试各科目考试时间表
  • 2009年上半年软件水平考试各科目考试时间表
  • 上海市2010年计算机软件水平考试报名通知
  • 浙江省2009年下半年计算机软件水平考试成绩查询
  • 广域网加速,如何选择网络产品
  • 应对年底网络运维危机
  • ip地址和MAC地址在三层交换机上的绑定
  • VLAN间的单向通信established命令
  • 发现和调用Dll里的函数
  • 递推关系算法
  • 稳步实施IPv6七大原则
  • 中小企业应该如何选型IP电话交换系统
  • 教你揪出伪装木马并清除
  • AES算法的数学基础
辅导专区
中级辅导
模拟试题
历年真题
  • [网络工程]AAA的概念和思科IOS对其配置的简要分析
  • [电子商务]选购防火墙当心5大误区
  • [软件设计]通用权限实现的核心设计思想
  • [网络工程]VPN内无法访问某些WEB站点故障
  • [网络工程]路由技术IP路由选择协议
  • [电子商务]PS高手秘技:如何在设计中出类拔萃
  • [电子商务]CIO选信息化合作伙伴的三个关键条件
  • [电子商务]经济危机中最受CIO青睐的五种技术
  • [软件设计]SharePoint工作流开发的一些概念
  • [软件设计]SharePoint工作流开发:HelloWorldSeque
  • 2009年5月份软考网络管理员每日一练试题 (12月31日
  • 2009年5月份软考网络管理员每日一练试题 (12月30日
  • 2009年上半年软考网络管理员每日一练试题 (12月29
  • 2009年上半年软考网络管理员每日一练试题 (12月28
  • 2009年上半年软考网络管理员每日一练试题 (12月27
  • 2009年上半年软考网络管理员每日一练试题 (12月26
  • 2009年上半年软考网络管理员每日一练试题 (12月25
  • 2009年上半年软考网络管理员每日一练试题 (12月23
  • 2009年上半年软考网络管理员每日一练试题 (12月22
  • 2008年12月软考软件设计师每日一练(12月20日)答
  • 2008年下半年软考信息处理技术员考试上午试题答案
  • 2008年下半年软考网络管理员考试上午试题评析(专家
  • 2008年下半年软考网络工程师考试上午试题评析(专家
  • 2007年上半年软考网络工程师考试下午试题
  • 2007年上半年软考网络工程师考试上午试题
  • 2008年下半年软考软件设计师上午试题参考答案(完整
  • 2008年下半年软考软件设计师下午试题参考答案(完整
  • 2008年下半年软考信息处理技术员真题上午试题专家
  • 2008年下半年软考网络工程师上午试题专家解读
  • 2008年下半年软考网络管理员真题下午试题专家版答
热门课程培训
更多
  • 璺�娴兼俺顓告禒搴濈瑹閼板啳鐦划鎹愵唹閻濓拷
  • 璺�閸掓繄楠囨导姘愁吀閼卞瞼袨娣囨繆绻冮悵锟�
  • 璺�閸掓繄楠囨导姘愁吀閼卞瞼袨閼板啳鐦划鎹愵唹閻濓拷
  • 璺�娑擃厾楠囨导姘愁吀閼卞瞼袨鐟欏棝顣舵潏鍛嚤
  • 璺�濞夈劌鍞芥导姘愁吀鐢牐鈧啳鐦潏鍛嚤
  • 璺�濞夈劌鍞界粙搴″鐢牐顕崇粙瀣窡鐎碉拷
  • 璺�鐠у嫪楠囩拠鍕強鐢牆鍟块崚杞扮瘎妫版ḿ褰�
  • 璺�妤傛ḿ楠囨导姘愁吀鐢牐鈧啳鐦稊鐘活暯閻濓拷
  • 璺�缂佸繑绁圭敮鍫b偓鍐槸鐟欏棝顣舵潏鍛嚤
  • 璺�鐠囦礁鍩滄禒搴濈瑹閼板啳鐦拠鍓р柤鏉堝懎顕�
  • 璺�閸愬懎顓哥敮鍫b偓鍐槸鐟欏棝顣舵潏鍛嚤
  • 璺�闁炬儼顢戞禒搴濈瑹閼板啳鐦潻婊呪柤鏉堝懎顕�
论坛新帖

关于我们 ┊ 合作加盟 ┊ 广告联系 ┊ 联系我们 ┊ 网站地图 ┊ 网站声明 ┊ 友情链接 ┊ 优易学QQ群联盟 ┊ 最新更新 ┊ 团队博客
热线:010-52880094  传真:010-52880094
投诉意见,请点这里在线提交或24小时QQ热线:53882478
Copyright © 2005-2012 YouYiXue.com All Rights Reserved 京ICP备09036865号-3