回溯递归:八皇后

 1 public static int[][] arry=new int[8][8];//棋盘,放皇后
 2 public static int map=0;//存储方案结果数量
 3 
 4 public static void main(String[] args) {
 5     // TODO Auto-generated method stub
 6 
 7     System.out.println("八皇后问题");
 8     findQueen(0);
 9     System.out.println("八皇后问题共有:"+map+"种可能");
10 }
11 
12 public static void findQueen(int i){//寻找皇后节点
13     if(i>7){//八皇后的解  
14         map++;
15         print();//打印八皇后的解
16         return;
17     }
18     
19     for(int m=0;m<8;m++){//深度回溯,递归算法
20         if(check(i,m)){//检查皇后摆放是否合适
21             arry[i][m]=1;
22             findQueen(i+1);
23             arry[i][m]=0;//清零,以免回溯的时候出现脏数据
24             }
25     }   
26 }
27 
28 public static boolean check(int k,int j){//判断节点是否合适
29     for(int i=0;i<8;i++){//检查行列冲突
30          if(arry[i][j]==1){
31                 return false;
32          }
33     }
34     for(int i=k-1,m=j-1; i>=0 && m>=0; i--,m--){//检查左对角线
35         if(arry[i][m]==1){
36                 return false;
37         }
38     }
39     for(int i=k-1,m=j+1; i>=0 && m<=7; i--,m++){//检查右对角线
40         if(arry[i][m]==1){
41                 return false;
42         }
43     }
44     return true;
45 }
46 
47 public static void print(){//打印结果
48     System.out.print("方案"+map+":"+"\n");
49     for(int i=0;i<8;i++){
50         for(int m=0;m<8;m++){
51             if(arry[i][m]==1){  
52                 //System.out.print("皇后"+(i+1)+"在第"+i+"行,第"+m+"列\t");
53                 System.out.print("o ");
54             }
55             else{
56                     System.out.print("+ ");
57             }
58         }
59         System.out.println();
60     }
61     System.out.println();
62 }

链接:https://www.jianshu.com/p/65c8c60b83b8

转载于:https://www.cnblogs.com/ZeGod/p/10488357.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值