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

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

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

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

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

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

#穷举法
rm(list=ls())
cat(rep("\n", 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))}
}
}
}
}
}
}
}
}

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

最新文章

  1. 如何在nuget上传自己的包+搭建自己公司的NuGet服务器(新方法)
  2. 接口测试SoapUI参数化
  3. Java-数组练习1
  4. css制作三角形
  5. java-源码下载
  6. SpringMVC+SwfUpload进行多文件同时上传
  7. Hibernate框架(一)——总体介绍
  8. 新浪微博布局学习——妙用TabHost
  9. 使用Session防止表单重复提交
  10. 数的计数(number)
  11. 【Spring】HttpMessageConverter的作用及替换
  12. Java不走弯路教程(1.环境搭建)
  13. tensorflow安装-【老鱼学tensorflow】
  14. Windows Phone MultiBinding :Cimbalino Toolkit
  15. centos 6.9安装python 3.6
  16. [PHP] 04 - Upload files
  17. Python---字典常用方法总结
  18. 默认五笔输入法qq
  19. PHP获取客户端的IP地址
  20. Java知识回顾 (3)运算符

热门文章

  1. windows10上同时安装py2和py3的情况
  2. Python学习之协程
  3. python_面试题_TCP的三次握手与四次挥手问题
  4. CF1187E Tree Painting【换根dp】
  5. 【FFMPEG】网络流媒体协议
  6. docker mysql 容器报too many connections 引发的liunx磁盘扩容操作
  7. oracle 11g sqlplus和plsql developer 乱码解决方案
  8. SpringMvc 整合mybatis项目搭建
  9. ucloud建新主机
  10. [转帖]java必备的开发知识和技能