N皇后问题
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submission(s): 5541 Accepted Submission(s): 2514
你的任务是,对于给定的N,求出有多少种合法的放置方法。
1 8 5 0
1 92 10
public class Main {
/**
* @param args
*/
static int[]c=new int[12];
static int tot;
public static void main(String[] args) {
// TODO Auto-generated method stub
for(int i=1;i<=10;i++){
tot=0;
System.out.println(search(0,i));
}
}//main
private static int search(int cur,int n){
if(cur==n)
tot++;
else{
for(int i=0;i<n;i++){
int ok=1;
c[cur]=i;
for(int j=0;j<cur;j++)
if(c[cur]==c[j]||cur-c[cur]==j-c[j]||cur+c[cur]==j+c[j])
{
ok=0;
break;
}
if(ok==1)
search(cur+1,n);
}
}
return tot;
}
}//Main
import java.util.Scanner;
public class Main {
/**
* @param args
*/
public static void main(String[] args) {
// TODO Auto-generated method stub
Scanner input=new Scanner(System.in);
while(true){
int n=input.nextInt();
if(n==0)
break;
else{
int[] a={1,0,0,2,10,4,40,92,352,724};
System.out.println(a[n-1]);
}
}
}
}