nqueen1.java

来自「数据结构与算法分析设计的实验作业」· Java 代码 · 共 38 行

JAVA
38
字号
public class NQueen1
{
	static int n;
	static int[] x;
	static long sum;
	
	public static long nQueen(int nn)
	{
		n=nn;
		sum=0;
		x=new int[n+1];
		for(int i=0;i<=n;i++) x[i]=0;
		backtrack(1);
		return sum;
	}
	private static boolean place(int k)
	{
		for(int j=1;j<k;j++)
		if((Math.abs(k-j)==Math.abs(x[j]-x[k]))||(x[j]==x[k]))return false;
		return true;
	}
	private static void backtrack(int t)
	{
		if(t>n) sum++;
		else
		   for(int i=1;i<=n;i++)
		     x[t]=i;
//System.out.println(x[t]);	
		     if(place(t))
		      backtrack(t+1);
		     
	}
	public static void main(String args[])
	{
	 
	 System.out.println(nQueen(4));	   
	}
}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?