八皇后问题

八皇后问题,是一个古老而著名的问题,是回溯算法的典型案例。该问题是国际西洋棋棋手马克斯·贝瑟尔于1848年提出:在8×8格的国际象棋上摆放八个皇后,使其不能互相攻击,即任意两个皇后都不能处于同一行、同一列或同一斜线上,问有多少种摆法。

代码实现

static int count = 0;//记录有几种方法
int max = 8;//max表示几个皇后
int[] arr = new int[max];//用一个数组表示,其中arr[n]表示放在第arr[n]+1列,n表示第n+1个皇后,放在第n+1行
public static void main(String[] args) {
EightQueen queen = new EightQueen();
queen.store(0);
System.out.printf("一共有%d种放置方法",count);
} //在棋盘上放置第几个皇后
private void store(int n){
if (n == 8){ //如果所有皇后放置完毕,则输出
print();
return;
}
for (int i = 0; i < max; i++) {
arr[n] = i;
if (Judg(n)){//判断是否与前面放置的有冲突
store(n + 1);
}
} } private boolean Judg(int n){
for (int i = 0; i < n; i++) {
//arr[i] == arr[n] 表示是否在同一列
//Math.abs(n - i) == Math.abs(arr[n] - arr[i]) 表示是否在同一斜线
if (arr[i] == arr[n] || Math.abs(n - i) == Math.abs(arr[n] - arr[i])){
return false;
}
}
return true;
} //用于显示八皇后的位置
private void print(){
count++;
for (int i = 0; i < arr.length; i++) {
System.out.print(arr[i] + 1 + " ");
}
System.out.println();
}

最新文章

  1. HDU2608-0 or 1(数论+找规律)
  2. Go语言执行系统命令行命令(转)
  3. 【Java每日一题】20161026
  4. HTMLTestRunner修改Python3的版本
  5. JavaWeb前端: JavaScript 简介
  6. CLR via C#深解笔记二 - 类型设计
  7. Xamarin.Android开发实践(十一)
  8. 装多系统删除某个系统后,如何恢复ubuntu引导
  9. arguments的基本用法
  10. android 利用TrafficStats类获取本应用的流量
  11. Apache Spark Streaming的优点
  12. scrollLeft,scrollWidth,clientWidth,offsetWidth 可实现导航栏固定不动(冻结)的效果
  13. oracle存储过程 --1
  14. Python3基础 list(zip()) 将两个列表打包起来
  15. Superwebsocket 模拟微信聊天室
  16. IDEA下创建Maven项目,并整合使用Spring、Spring MVC、Mybatis框架
  17. 最新swift4.0 图片进行尺寸大小及体积压缩
  18. Proxy SwitchyOmega配合Shawdowsocks使用的配置
  19. AIM Tech Round 5 (rated, Div. 1 + Div. 2) (A, B, E)
  20. python 编码 自动加双斜杠问题

热门文章

  1. HDU2937 YAPTCHA(威尔逊定理)
  2. P1516 青蛙的约会和P2421 [NOI2002]荒岛野人
  3. idea 将项目托管到 Git 报错:Can&#39;t finish Gitee sharing process
  4. 题目分享M
  5. 跟哥一起学python(4)- 数据类型之Number
  6. 最长公共子序列(Longest common subsequence)
  7. windows下flume 采集如何支持TAILDIR和tail
  8. E - 梦幻岛宝珠 HYSBZ - 1190 变形01背包 难
  9. 补一下昨天的博客 J - Sabotage 网络流
  10. SpringBoot:整合Shiro