B N皇后問題

2021-08-05 18:30:11 字數 690 閱讀 8930

在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個皇...