一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術(shù)|正則表達(dá)式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務(wù)器之家 - 編程語言 - Java教程 - Java基于循環(huán)遞歸回溯實(shí)現(xiàn)八皇后問題算法示例

Java基于循環(huán)遞歸回溯實(shí)現(xiàn)八皇后問題算法示例

2020-11-13 10:43qq7342272 Java教程

這篇文章主要介紹了Java基于循環(huán)遞歸回溯實(shí)現(xiàn)八皇后問題算法,結(jié)合具體實(shí)例形式分析了java的遍歷、遞歸、回溯等算法實(shí)現(xiàn)八皇后問題的具體步驟與相關(guān)操作技巧,需要的朋友可以參考下

本文實(shí)例講述了Java基于循環(huán)遞歸回溯實(shí)現(xiàn)八皇后問題。分享給大家供大家參考,具體如下:

運(yùn)行效果圖如下:

Java基于循環(huán)遞歸回溯實(shí)現(xiàn)八皇后問題算法示例

棋盤接口

?
1
2
3
4
5
6
7
8
9
/**
 * 棋盤接口
 * @author Administrator
 *
 */
public interface Piece {
  abstract boolean isRow(int line);
  abstract boolean isCol(int line,int col);
}

棋盤類:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
/**
 * 棋盤
 * @author Administrator
 *
 */
public class Chessboard implements Piece {
  static boolean[][] che = null;
  public int row;
  public int col;
  private int num=0;
  public Chessboard (int row,int col){
    this.che=new boolean[row][col];
    this.row=row;
    this.col=col;
  }
  //當(dāng)前行是否能放棋子
  public boolean isRow(int line){
    for (int i = 0; i < this.row; i++) {
      if (che[i][line] == true) {
        return false;
      }
    }
    return true;
  }
  //棋子邊角
  public boolean isCol(int line,int col){
    int i = 0, j = 0;
    for (i = line, j = col; i < this.row && j < this.row; i++, j++) { //右下角;
      if (che[i][j] == true) {
        return false;
      }
    }
    for (i = line, j = col; i >= 0 && j >= 0; i--, j--) { //左上角;
      if (che[i][j] == true) {
        return false;
      }
    }
    for (i = line, j = col; i >= 0 && j < this.row; i--, j++) { // 右上角;
      if (che[i][j] == true) {
        return false;
      }
    }
    for (i = line, j = col; i < this.row && j >= 0; i++, j--) { //左下角;
      if (che[i][j] == true) {
        return false;
      }
    }
    return true;
  }
  public void pr() {//打印滿足條件的擺放方法
    num++;
    System.out.println("第" + num + "種方式");
    System.out.print("-------------start-------------");
    for (int i = 0; i < this.row; i++) {
      System.out.println();
      for (int j = 0; j < this.row; j++) {
        if (che[i][j] == true) {
          System.out.print("Q ");
        } else {
          System.out.print(". ");
        }
      }
    }
    System.out.println();
    System.out.println("-------------end-------------");
  }
}

皇后類

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
/**
 * 皇后
 * @author Administrator
 *
 */
public class empress {
  private Chessboard che=null;
  private int count=0;
  private int row=0;
  public empress(int row,int col){
    this.che=new Chessboard(row,col);
    this.row=row;
  }
  //主要的遞歸實(shí)現(xiàn)方法
  public void mk(int line) {
    if (line > this.row-1)
      return;//超過行則退出
    for (int i = 0; i < this.row; i++) {
      if (che.isRow(i) && che.isCol(line,i)) { //ture 為可以擺皇后;
        che.che[line][i] = true; //
        count++; //
        if (count > this.row-1) {
          che.pr();//擺放皇后8個(gè)則打印結(jié)果
        }
        mk(line + 1);//遞歸
        che.che[line][i] = false; //回溯
        count--;
        continue;
      }
    }
    return;
  }
}

啟動(dòng):

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.util.Scanner;
import javax.swing.JOptionPane;
public class start {
  public static void main(String[] args) {
    String inputrow = JOptionPane.showInputDialog("輸入行:");
    int row = Integer.parseInt(inputrow);
    String inputcol = JOptionPane.showInputDialog("輸入列:");
    int col = Integer.parseInt(inputcol);
    empress emp=new empress(row,col);
    emp.mk(0);
  }
}

希望本文所述對(duì)大家java程序設(shè)計(jì)有所幫助。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 国内外成人在线视频 | 操老逼 | www四虎影视 | 国产va免费精品高清在线 | 午夜精品久久久久久久99蜜桃i | 麻豆最新地址 | 四虎精品成人a在线观看 | 天天做天天爱天天操 | 午夜香蕉成视频人网站高清版 | 清纯漂亮女友初尝性过程 | 欧美男同互吃gay老头 | 亚洲四虎影院 | 九九在线精品视频 | 天天做天天爱天天综合网 | 猛h辣h高h文湿重口 门房秦大爷在线阅读 | 欧美视频黑鬼大战白妞 | 91美女在线 | 日本xxx片免费高清在线 | 国产99视频精品免视看9 | 亚洲精品欧洲久久婷婷99 | 亚洲国产精品第一区二区三区 | 欧美亚洲国产另类在线观看 | 99国产情在线视频 | 国产综合图区 | 国产一级精品高清一级毛片 | 免费观看视频在线 | 黄a 大片a v 永久免费 | 视频免费观看在线播放高清 | 美女脱了内裤张开腿亲吻男生 | 欧美成人禁片在线观看俄罗斯 | 俄罗斯美女大逼 | 1377大但人文艺术包子铺 | 大胆暴露亚洲美女xxxx | 亚洲2023无矿砖码砖区 | 久久九九有精品国产23百花影院 | 2021国产精品视频一区 | 人人爽人人草 | 男男双性生子产乳高辣h | 美女的隐私无遮挡撒尿 | 精品视频国产 | 日本欧美强乱视频在线 |