八皇后 简洁易懂版---东瀛杀猪萝卜丝

原创 2016年08月31日 15:48:20

这段时间一直在研究oracle 性能的优化加python的学习,所以没什么具体产量,正好看到python里有个例题是解决经典算法八皇后的,就手痒想这怎么用java去实现,当然最开始第一反映是两层for去死循环,对于一个有点想法或者编程经验的程序猿来说,这是绝对不应该的。

可能各位同学有的没听过八皇后算法

这里解释一下


八皇后问题是一个以国际象棋为背景的问题:如何能够在8×8的国际象棋棋盘上放置八个皇后,使得任何一个皇后都无法直接吃掉其他的皇后?为了达到此目的,任两个皇后都不能处于同一条横行、纵行或斜线上。

刚开始看的时候只考虑了邻近两行的可能,即上行和下行,没有考虑到隔着的行数,所以代码也就有可以完善的部分。。


代码分为两个部分

第一个部分 是循环+递归(对行数进行递归,对列数进行循环)

第二个部分  检查当前位置是否可以摆放皇后


贴上代码

package lobs.jibunn.mb.jp.suanfa;

public class EightQueen {

	static int num = 0;
	public EightQueen() {
		// TODO Auto-generated constructor stub
		for(int i = 0; i < 8;i++) {
			for(int j = 0; j < 8;j++) {
			     a[i][j] = 0;
		    }
		}
	}

	static int a[][] = new int[8][8];
	
	public static void main(String args[]) {
		placeQueen(0);
	}
	
	public static void placeQueen(int x){
		for(int i= 0;i < 8; i++) {
			if (x == 8 ) {
				printResult();
				break;
			}
			if(checkPosition(x,i)) {
				a[x][i] = 1;
				placeQueen(x+1);
			}			
		}
	}
	public static boolean checkPosition(int x, int y) {
		for (int i = 0;i < 8; i++) {
			a[x][i] = 0;
		}
		if (x == 0) {
			return true;
		}
		
		if ( y == 0
				&& x < 7) {
			if (a[x-1][y] +
					+ a[x-1][y+1]  > 0
					) {
				return false;
			} else {
				return true;
			}
		}
		
		if ( x == 7
				&& y == 0) {
			if (a[x-1][y] +
					+ a[x-1][y+1] > 0

					) {
				return false;
			} else {
				return true;
			}
		}
		
		if ( x == 7
				&& y < 7) {
			if (a[x-1][y] +
					+ a[x-1][y+1] 
							+ a[x-1][y-1]> 0) 
			{
				return false;
			} else {
				return true;
			}
		}

		if ( y == 7
				&& x <= 7) {
			if (a[x-1][y] 
					+ a[x-1][y-1] > 0
					) {
				return false;
			} else {
				return true;
			}
		}
		
		if (x == 7 && y == 0) {
			if (a[x-1][y] + a[x-1][y+1] == 0) {
				return false;
			}else {
				return true;
			}
		}
		
		if (a[x-1][y +1] 
				+ a[x-1][y-1] 
				+ a[x-1][y] > 0
				) {
			return false;
		} 
        return true;
	} 
	
	private static void printResult(){
		System.out.print(num++ +"-------------------------------------"); 
		for(int i = 0; i < 8;i++) {
			System.out.print("\n");
			for(int j = 0; j < 8;j++) {
			     System.out.print(a[i][j]);
		    }
		}
		System.out.print("\n");
	}
}
但是注意了

这个检验只对前后左右斜8个位置进行判断,并不包括隔行,有兴趣的同学可以自己完善下啦


版权声明:本文为博主原创文章,未经博主允许不得转载。

八皇后问题(最简单的递归解法)

题目 原文: Write an algorithm to print all ways of arranging eight queens on a chess board so that...
  • yangting09032214
  • yangting09032214
  • 2015年08月27日 15:24
  • 1413

python基础: 遍历与八皇后问题浅析

python基础: 遍历与八皇后问题
  • u014386870
  • u014386870
  • 2015年03月10日 15:02
  • 3039

八皇后问题不同思路解答

八皇后问题不同思路解答:算法提出:​在国际象棋棋盘上(8*8)放置八个皇后,使得任意两个皇后之间不能在同一行,同一列,也不能位于同于对角线上。问共有多少种不同的方法,并且指出各种不同的放法。思路一:回...
  • u014595375
  • u014595375
  • 2016年10月29日 01:49
  • 367

C++简单实现八皇后问题

近来无聊,想着几年前用c#实现的八皇后,是参考网上的答案,如今过了几年,想试试有没进步,用c++简单地实现。 八皇后问题,是回溯算法的经典例子,它的规则要求是同一行同一列同一条斜线不能有两个皇后,不然...
  • xanxus46
  • xanxus46
  • 2014年03月21日 16:35
  • 6566

回溯法求解八皇后问题

问题描述:八皇后问题是一个以国际象棋为背景的问题:如何能够在 8×8 的国际象棋棋盘上放置八个皇后,使得任何一个皇后都无法直接吃掉其他的皇后?为了达到此目的,任两个皇后都不能处于同一条横行、纵行或斜线...
  • gao1440156051
  • gao1440156051
  • 2014年03月07日 09:52
  • 7698

从算法学起C语言--八皇后(普通算法)

转载请注明出处,谢谢~ 背景说明: 西洋棋中的皇后可以直线,斜线吃掉所遇到的棋子,如果在8*8的棋盘上有八个皇后,则这八个皇后如何相安无事的摆放在棋盘上?1970年与1971年,E.W.Dijkstr...
  • u011200844
  • u011200844
  • 2015年01月30日 15:44
  • 1635

回溯算法(BackTracking)--八皇后问题

0) 回溯算法: 回溯算法也算是遍历算法的一种,回溯算法是对Brute-Force算法的一种改进算法,一个典型的应用是走迷宫问题,当我们走一个迷宫时,如果无路可走了,那么我们就可以退一步,再在其他的路...
  • changyuanchn
  • changyuanchn
  • 2013年12月16日 22:17
  • 11127

数据结构应用案例——栈结构用于8皇后问题的回溯求解

【说明】本文来自由周世平老师主编的《C语言程序设计》教材。我作为参编人员执笔了第7、8章。“第8章 问题求解与算法”中“8.6.1 回溯法”以8皇后问题的求解为例,介绍了回溯法的解题过程。这个解决方案...
  • sxhelijian
  • sxhelijian
  • 2015年10月05日 15:21
  • 5695

八皇后问题的递归解法(最易理解的版本)

八皇后问题是一个古来而著名的问题,该问题是19世纪著名的数学家高斯同学提出来的。在8*8的国际象棋上摆放八个皇后,使其不能互相的攻击,也就是说,任意的两个皇后不能放在同一行或则是同一个列或者是同一个对...
  • nmgrd
  • nmgrd
  • 2017年03月23日 20:56
  • 790

八皇后问题(递归回溯+迭代回溯)

八皇后问题是一个以国际象棋为背景的问题:如何能够在 8×8 的国际象棋棋盘上放置八个皇后,使得任何一个皇后都无法直接吃掉其他的皇后?为了达到此目的,任两个皇后都不能处于同一条横行、纵行或斜线上。八皇后...
  • u013351484
  • u013351484
  • 2015年04月04日 14:53
  • 539
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:八皇后 简洁易懂版---东瀛杀猪萝卜丝
举报原因:
原因补充:

(最多只允许输入30个字)