在n*n的方格棋盤放置了n個皇后,使得它們不相互攻擊(即任意2個皇后不允許處在同一排,同一列,也不允許處在與棋盤邊框成45角的斜線上。
你的任務是,對於給定的n,求出有多少種合法的放置方法。
input
共有若干行,每行乙個正整數n≤10,表示棋盤和皇后的數量;如果n=0,表示結束。
output
共有若干行,每行乙個正整數,表示對應輸入行的皇后的不同放置數量。
sample input
185
0
sample output
1
9210
#include#include#include#include#includeusing namespace std;
int x[100],sum1[100];//x[i]用來標記第i個皇后的列數
int sum=0,n;
int abs(int t)
int check(int a)//判斷第a個皇后能是不是和之前a-1個皇后在對角線和同一列上
}return sum;
}int main()
int j;
while(cin>>j&&j)
return 0;
}
B N皇后問題
一天課下,張老闆研究起了西洋棋,渴望完美的他更改了棋盤的大小,在n n的方格棋盤放置了n個皇后,希望它們不相互攻擊 即任意2個皇后不允許處在同一排,同一列,也不允許處在與棋盤邊框成45角的斜線上 張老闆把這個艱鉅的任務交給了你,對於給定的n,求出有多少種合法的放置方法。input共有若干行,每行乙個...
問題 B N的階乘
求高精度乘於低精度的方法,如下所示,d陣列最好開大點,至於n的階乘,就初始化從1開始累積乘,進行吸收即可,記得初始化第乙個數字1,即結果,至少為1,高精度的乘法即把 乘數 當成乙個整體,不斷的乘,進製,接著進行必要的剩下的數的儲存,用while 搞精度乘法必須把 乘數當成乙個整體!和加法基本上是一致...
問題 I n皇后問題
在n n 格的棋盤上放置彼此不受攻擊的n 個皇后。按照西洋棋的規則,皇后可以攻擊與之處在同一行或同一列或同一斜線上的棋子。n後問題等價於在n n格的棋盤上放置n個皇后,任何2 個皇后不放在同一行或同一列或同一斜線上。設計乙個解n 後問題的佇列式分支限界法,計算在n n個方格上放置彼此不受攻擊的n個皇...