• R语言-八皇后问题


    老师给我出了个暑期作业:用R语言解决八皇后问题。

    八皇后问题:国际象棋棋盘(8×8)上放8个“后”,使8个“后”之间互相不能被进攻。(即:每个“后”所在行、列、两条斜线都没有其它子)

    查看网上,大多用C++,没看到用R的。呵呵,看来是不能借鉴了。

    第一感觉是,应该不能穷举,否则运行非常慢,在网上看了些介绍,打算用回溯法。

    然而水平有限,搞了一天多竟然还没成功写好,总是有很奇怪的bug,唉,怪我对R不熟悉吧。

    刚才生气了,干脆来个穷举,看看能运行多久,代码见下,看起来非常笨拙,结果运行2,3秒就完成了。。。还是不了解计算机、不了解R啊。。。

    #穷举法
    rm(list=ls())
    cat(rep("
    ", 50))
    b1=array(numeric(64),dim=c(8,8))
    i=0;j=1:8
    for (d1 in j){
     D2=setdiff(j,d1)
     for (d2 in D2){
      D3=setdiff(D2,d2)
      for (d3 in D3){
       D4=setdiff(D3,d3)
       for (d4 in D4){
        D5=setdiff(D4,d4)
    	for (d5 in D5){
         D6=setdiff(D5,d5)
    	 for (d6 in D6){
          D7=setdiff(D6,d6)
    	  for (d7 in D7){
           D8=setdiff(D7,d7)
    	   for (d8 in D8){
               if(
    		   (d2-d1==1)|(d3-d1==2)|(d4-d1==3)|(d5-d1==4)|(d6-d1==5)|(d7-d1==6)|(d8-d1==7)|#左上-右下
    		   (d3-d2==1)|(d4-d2==2)|(d5-d2==3)|(d6-d2==4)|(d7-d2==5)|(d8-d2==6)|(d4-d3==1)|
    		   (d5-d3==2)|(d6-d3==3)|(d7-d3==4)|(d8-d3==5)|(d5-d4==1)|(d6-d4==2)|(d7-d4==3)|
    		   (d8-d4==4)|(d6-d5==1)|(d7-d5==2)|(d8-d5==3)|(d7-d6==1)|(d8-d6==2)|(d8-d7==1)|
    		   (d2-d1==-1)|(d3-d1==-2)|(d4-d1==-3)|(d5-d1==-4)|(d6-d1==-5)|(d7-d1==-6)|(d8-d1==-7)|#左下-右上
    		   (d3-d2==-1)|(d4-d2==-2)|(d5-d2==-3)|(d6-d2==-4)|(d7-d2==-5)|(d8-d2==-6)|(d4-d3==-1)|
    		   (d5-d3==-2)|(d6-d3==-3)|(d7-d3==-4)|(d8-d3==-5)|(d5-d4==-1)|(d6-d4==-2)|(d7-d4==-3)|
    		   (d8-d4==-4)|(d6-d5==-1)|(d7-d5==-2)|(d8-d5==-3)|(d7-d6==-1)|(d8-d6==-2)|(d8-d7==-1)
    		   )
    		   {break}
    		   else{i=i+1;print(paste(d1,d2,d3,d4,d5,d6,d7,d8))}
           }
          }
         }
        }
       }
      }
     }
    }
    

      不过以后还是要尝试一下回溯法的解决方案。

  • 相关阅读:
    weblogic12c 2021.4.20 季度补丁 SPB
    一顿debug猛如虎,原来内存OOM
    JDK记录一下
    213. 打家劫舍 II-动态规划-中等
    5526. 最多可达成的换楼请求数目-回溯-困难
    1584. 连接所有点的最小费用-图/最小生成树-中等
    Java-泛型的限制
    Java-泛型-桥方法
    889. 根据前序和后序遍历构造二叉树-树-中等
    1109. 航班预订统计-差分数组-中等
  • 原文地址:https://www.cnblogs.com/maoerbao/p/11304315.html
Copyright © 2020-2023  润新知