亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

回溯法解決2n皇后(8皇后)問題

2019-11-11 04:44:27
字體:
來源:轉載
供稿:網友

8皇后問題是算法入門的經典,在8*8的國際象棋上擺放八個皇后,使其不能相互攻擊,即任意兩個皇后都不能處于同一

行,同一列,或者同一斜線上。關于8皇后的解法請見:http://www.cnblogs.com/newflydd/p/5091646.html

今天要說的2n皇后問題與傳統的8皇后問題有些不同,在一個n*n的棋盤中,有些位置不允許放皇后,現在要向棋盤中

放入n個黑皇后和n個白皇后,使任意的兩個黑白皇后都不在同一行,同一列或者同一條對角線上。看起來問題變得有

些復雜了,但其實本質上還是8皇后問題。

我們使用回溯算法和遞歸的思想來解決這個問題。每行只能放置一個黑皇后和一個白皇后,從第一行第一列開始放

置,假設第一行第一列放置白皇后,那么黑皇后在第一排的位置就還有n-1中可能,依次檢測每一種可能性,首先將

黑皇后放在第一排第二列的位置。然后放置第二排,在放第二排時就需要考慮到皇后的擺放規則,打個比方說在第二

排第一列放一個白皇后,那么此時就需要進行檢測,白皇后的位置是否安全可行,明顯的一列只能放一個白皇后,所

以這個皇后的擺放位置不可行,重新擺放,在重新擺放之前會清除本行原本的擺放記錄。當這一排的所有位置都不能

安全的擺放兩個皇后時,就需要退回到上一行的擺放,清楚上一行原本的擺放記錄,重新擺放。

直到第一次擺放到最后一行,并且棋盤中的黑白皇后數量正確,此時才算是得出了一個正解。到這里程序并不會結

束,因為得到一個正解并不等于嘗試完所有的可能性,程序只有在嘗試完所有的可能擺放皇后位置以后,才會結束。

了解算法的思路以后代碼的框架也就出來了,用一個二維數組模擬棋盤,默認值為0和1,0即為此位置不可以擺放皇

后,在擺放皇后時也需要對此進行驗證,這里我們用6代表白皇后,9代表黑皇后,放置皇后也就是改變數組中指定位

置的數值。在驗證擺放皇后位置是否可行時,需要判斷三個方向是否有該種皇后,即兩條對角線和本列,而且只需要

考慮皇后所在行的上面,因為下面還沒有擺放皇后啊!為了便于處理,將棋盤分為三部分(除去第一行,第一行不需

要判斷),第一部分為第一列,第二部分為最后一列,第三部分為其他列。這樣分第一部分和第二部分只需要考慮一

條對角線,只有第三部分需要考慮兩條。

import java.util.Scanner;public class Demo4 {	PRivate static int result = 0;		public static boolean isSafety(short[][] chess, int row, int x, int queen) {				if (row != 0 && x != 0 && x != chess.length - 1) {						int step=1,step2=1;			while(row-step>=0&&x+step<=chess.length-1){				if(chess[row-step][x+step]==queen){					return false;					}				step++;			}			while(row-step2>=0&&x-step2>=0){				if(chess[row-step2][x-step2]==queen){					return false;					}				step2++;			}		}			if (row != 0 && x == 0) {			int step=1;			while(row-step>=0&&x+step<=chess.length-1){				if(chess[row-step][x+step]==queen){					return false;					}				step++;			}		}		if (row != 0 && x == chess.length-1) {			int step=1;			while(row-step>=0&&x-step>=0){				if(chess[row-step][x-step]==queen){					return false;					}				step++;			}		}		for (int i = 0; i < row; i++) {			if (chess[i][x] == queen) {				return false;				}		}		return true;	}	public static void putQueen(short[][] chess, int row) {		// 擺完一盤		if (row == chess.length) {			if(queenNumber(chess)){				result++;			}				return;		}		for (int i = 0; i < chess.length; i++) {			//清除原本的擺放記錄			for (int j = 0; j < chess.length; j++) {				if(chess[row][j]!=0){					chess[row][j] = 1;				}			}			if (isSafety(chess, row, i, 6)&&chess[row][i]==1) {				//擺放白皇后				chess[row][i] = 6;				for (int k = 0; k < chess.length; k++) {					//清除原本的擺放記錄					for (int l = 0; l < chess.length; l++) {						if (chess[row][l] != 0 && l != i) {							chess[row][l] = 1;						}					}					if (isSafety(chess, row, k, 9)&&chess[row][k]==1&&k != i) {						//擺放黑皇后						chess[row][k]=9;						//擺放下一行						putQueen(chess, row + 1);					}				}			}		}	}	public static boolean queenNumber(short[][] chess){		int white=0,black=0;		for(int i=0;i<chess.length;i++){			for(int j=0;j<chess.length;j++){				if(chess[i][j]==6){					white++;				}				if(chess[i][j]==9){					black++;				}							}		}		if(white==chess.length&&black==chess.length){			return true;		}		return false;	}	public static void main(String[] args) {		Scanner console = new Scanner(System.in);		int n = console.nextInt();		short[][] chess = new short[n][n];		for (int i = 0; i < n; i++) {			for (int j = 0; j < n; j++) {				chess[i][j] = (short) console.nextInt();			}		}		putQueen(chess, 0);		System.out.println(result);	}}

控制臺Sample:

41 0 1 1 1 1 1 11 1 1 11 1 1 10


上一篇:PAT BASIC 1006

下一篇:bean的生命周期

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日韩亚洲欧美成人| 色偷偷综合社区| 亚洲第一区中文99精品| 亚洲欧美综合图区| zzijzzij亚洲日本成熟少妇| 日韩欧美亚洲一二三区| 久久久综合免费视频| 国产中文字幕日韩| 日本精品视频在线| 中文字幕精品影院| 国产精品视频男人的天堂| 亚洲欧美中文字幕| 精品欧美激情精品一区| 日韩一二三在线视频播| 久久免费国产视频| 日韩欧美在线免费| 亚洲综合大片69999| 日韩精品视频免费专区在线播放| 欧美亚洲一区在线| 亚洲成人国产精品| 国产不卡一区二区在线播放| 国产一区二区美女视频| 精品欧美一区二区三区| 欧美午夜精品久久久久久浪潮| 亚洲第一中文字幕| 国产丝袜一区二区| 国产成人精品综合| 欧美一级视频免费在线观看| 国产在线观看精品一区二区三区| 久久亚洲综合国产精品99麻豆精品福利| 久久久噜噜噜久久中文字免| 亚洲成人黄色网址| www高清在线视频日韩欧美| 亚洲日韩欧美视频| 亚洲精品av在线播放| 日韩国产精品视频| 国产99视频在线观看| 亚洲一区二区三区sesese| 中文字幕欧美视频在线| 92看片淫黄大片看国产片| 国产午夜精品视频免费不卡69堂| 成人妇女淫片aaaa视频| 日产日韩在线亚洲欧美| 亚洲天堂开心观看| 欧美大胆在线视频| 欧美国产日韩一区| 欧美噜噜久久久xxx| 欧美超级免费视 在线| 国产精品吹潮在线观看| 91精品久久久久久久久不口人| 成人黄色片网站| 夜色77av精品影院| 欧美成人一区在线| 欧美中文字幕视频在线观看| 综合欧美国产视频二区| 精品偷拍各种wc美女嘘嘘| 欧美裸体男粗大视频在线观看| 日本精品在线视频| 91在线观看免费高清| 日韩av在线一区| 欧美高跟鞋交xxxxxhd| 最近2019免费中文字幕视频三| 国产精品久久久久久久久久免费| 青青精品视频播放| 日韩欧美在线第一页| 久久亚洲精品毛片| 日韩欧美成人精品| 亚洲自拍偷拍色片视频| 国产亚洲人成网站在线观看| 97久久精品人搡人人玩| 丝袜美腿亚洲一区二区| 欧美成人国产va精品日本一级| 亚洲国产日韩一区| 亚洲午夜色婷婷在线| 欧美成人在线免费| 欧美刺激性大交免费视频| 国产精品扒开腿做爽爽爽视频| 日韩中文理论片| 日韩少妇与小伙激情| 久久九九全国免费精品观看| 久久亚洲精品网站| 91免费的视频在线播放| 久久久久久久久亚洲| 91超碰caoporn97人人| 97色在线视频观看| 国产精品丝袜久久久久久不卡| 日韩高清有码在线| 国产精品一区专区欧美日韩| 91成人在线视频| 日韩一区二区精品视频| 中文字幕日韩专区| 国产精品69久久久久| 伊人久久精品视频| 亚洲色图50p| 一本色道久久88亚洲综合88| 国产一区二区三区毛片| 一区二区三区日韩在线| 中文字幕免费国产精品| 精品国产一区久久久| 2019最新中文字幕| 久久人91精品久久久久久不卡| 国产精品视频久久| 国产精品自拍网| 亚洲精品久久久久久久久久久久久| 丰满岳妇乱一区二区三区| 26uuu另类亚洲欧美日本老年| 亚洲情综合五月天| 国产精品激情av在线播放| 亚洲人成电影网站色| 国产精品18久久久久久首页狼| 欧美午夜精品伦理| 欧美日韩国产精品一区二区三区四区| 欧美一级视频免费在线观看| 午夜精品三级视频福利| 麻豆国产精品va在线观看不卡| 国语自产精品视频在免费| 性欧美暴力猛交69hd| 久久久久久噜噜噜久久久精品| 国产精品一区=区| 日韩精品免费在线播放| 一区二区三区精品99久久| 国产女同一区二区| 久久久av亚洲男天堂| 亚州国产精品久久久| 欧美理论在线观看| 国产国产精品人在线视| 欧美乱大交xxxxx另类电影| 亚洲欧美综合区自拍另类| 欧美电影院免费观看| 国产深夜精品福利| 亚洲的天堂在线中文字幕| 久久国产精品久久精品| 日本久久亚洲电影| 69**夜色精品国产69乱| 欧美在线视频一二三| 日本19禁啪啪免费观看www| 国产成人精品久久二区二区91| 国产丝袜视频一区| 不用播放器成人网| 亚洲在线视频观看| 国产一区深夜福利| 奇米影视亚洲狠狠色| 国产精品久久综合av爱欲tv| 国产精品国产三级国产专播精品人| 日韩av最新在线观看| 成人国产精品免费视频| 亚洲国产小视频在线观看| 亚洲欧美日韩精品久久| 国产成人精品综合久久久| 精品在线观看国产| 国产91热爆ts人妖在线| 日韩最新中文字幕电影免费看| 久久久午夜视频| 国产精品久久999| 日韩欧美中文字幕在线播放| 日韩视频在线观看免费| 欧美大成色www永久网站婷| 午夜精品视频在线| 日韩av手机在线看| 日韩大片免费观看视频播放| 91国内产香蕉| 亚洲香蕉成人av网站在线观看| 国产精品老女人精品视频| 岛国av在线不卡|