当前位置: 首页 > news >正文

dw做网站简单吗/云南网络推广公司排名

dw做网站简单吗,云南网络推广公司排名,青岛外贸公司联系方式,博业建站网问题八皇后问题是一个古老而著名的问题,是回溯算法的典型例题。该问题是十九世纪著名的数学家高斯1850年提出:在8X8格的国际象棋上摆放八个皇后,使其不能互相攻击,即任意两个皇后都不能处于同一行、同一列或同一斜线上&#xff0c…

问题

八皇后问题是一个古老而著名的问题,是回溯算法的典型例题。该问题是十九世纪著名的数学家高斯1850年提出:在8X8格的国际象棋上摆放八个皇后,使其不能互相攻击,即任意两个皇后都不能处于同一行、同一列或同一斜线上,问有多少种摆法

百度来的代码

回溯法用递归实现八皇后解法

declaretype t_queen is varray(8) of number;queen t_queen := t_queen(1, 2, 3, 4, 5, 6, 7, 8);l_num number := 0;-- 显示“八皇后”procedure show(queen t_queen) isbeginl_num := l_num + 1;dbms_output.put_line(rpad('---- NO. ' || l_num || ' ', 16, '-'));-- 从第1行显示到第8行for r in 1 .. 8 loop-- 当前行,从第1列显示到第8列for c in 1 .. 8 loop-- “皇后”用“Q”表示,空位用“.”表示dbms_output.put(case when queen(r) = c then 'Q' else '.'end || ' ');end loop;dbms_output.put_line(null);end loop;end;-- 冲突检测。检测第row行与第1行至第row-1行是否冲突。-- 不冲突,返回true;冲突返回falsefunction is_ok(queen t_queen, row number) return boolean ist number;beginfor r in 1 .. row - 1 loopif queen(r) = queen(row) then-- 第row行与第r行的皇后在同一列上,冲突return false;end if;t := queen(r) - queen(row);if t = r - row or t = row - r then-- 第row行与第r行的皇后在同一斜线上,冲突return false;end if;end loop;return true;end;-- 递归查找所有排列procedure find(queen in out t_queen, row number) isbeginfor col in 1 .. 8 loop-- 每一行列的位置从第1列到第8列检测queen(row) := col;if is_ok(queen, row) thenif row = 8 then-- 已经查找到第8行,查找结束,显示结果show(queen);return;end if;find(queen, row + 1); -- 尚未查找到第8行,第归查找一下行end if;end loop;end;
beginfind(queen, 1); -- 从第1行开始查找
end;

运行结果

image

共92种结果

还有百度到了另外一种更简洁的写法

利用Oracle 11R2版本的递归属性,算法很简单,也就是在斜线上,直线上无冲突即可

with sou as (select level n,1 k from dual connect by  level<=8
),ntt(n,k) as (select sou.n ,sou.k  from sou where k=1union allselect ntt.n*10+a.n,ntt.k+1 from ntt,sou awhere not exists(select 1from  (select level b1 from dual connect by level<=7) twhere t.b1<=ntt.k and (a.n=to_number(substr(to_char(ntt.n),b1,1)) ora.n=to_number(substr(to_char(ntt.n),b1,1))+(ntt.k+1-t.b1) ora.n=to_number(substr(to_char(ntt.n),b1,1))-(ntt.k+1-t.b1))) and ntt.k<=7)
select n from ntt where ntt.k=8  ;

也是92种结果image

结果是一个数字表示在棋盘上的位置,也可以改一下用两位整数表示一个棋位,这样可以扩展到10皇后以上

时间因素:image也即每增加一个皇后,增加的时间约为上一个的e(x+1)倍

转载于:https://www.cnblogs.com/yongestcat/p/11555885.html

http://www.jmfq.cn/news/5296105.html

相关文章:

  • 南阳企业网站制作/中国最新领导班子
  • adobe建网站/百度竞价点击软件
  • wordpress主题转html/网站seo优化包括哪些方面
  • 青岛品牌设计/网站做优化好还是推广好
  • 滴道网站建设/线上营销模式有哪些
  • 网站的文件结构/seo点击工具
  • 如何申请自己的网站空间/品牌互动营销案例
  • 和田做网站的联系电话/聚合搜索引擎接口
  • 重庆网站建设方案书/seo包年服务
  • 昆明好的网站制作/长春网站建设定制
  • 设计公司网站官网/域名ip查询
  • 室内装饰公司网站模板/广告加盟
  • 做网站的升级人/seo常用的优化工具
  • 旅游地网站制作/nba最新交易消息
  • jquery 打开新网站/全球最大的磁力搜索引擎
  • 山东高端网站建设wang/icp备案查询官网
  • 南京百度网站建设/百度收录工具
  • 网站做动态和静态哪个贵/百度网站排名优化
  • 做软装搭配的网站/百度网站app下载
  • 京东商城网站风格/上海关键词排名手机优化软件
  • 500强企业网站建设/宁波seo教程行业推广
  • 网站开发常用png/seo专业优化公司
  • 北京大型网站建设公司/石家庄seo代理商
  • 两个彩票网站做赔付/上海seo优化公司
  • 自适应网站做百度推广/中文搜索引擎排名
  • 如何做微信商城网站建设/培训机构咨询
  • 做购物网站的目的/网页制作在线生成
  • 网站建设补贴/深圳seo推广公司
  • 购物网站开发目的/爱站网收录
  • 深圳市企业网站seo营销工具/免费建一个自己的网站