国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發設計 > 正文

P1219 八(N)皇后

2019-11-10 20:23:31
字體:
來源:轉載
供稿:網友

題目描述

有一個N*N的棋盤,有N個棋子被放置在棋盤上,使得每行、每列有且只有一個,每條對角線上至多有一個棋子,輸出前三個解和解的總數。

樣例輸入

6

樣例輸出

2 4 6 1 3 53 6 2 5 1 44 1 5 2 6 34

思路

O(2^n)我要嚴重吐槽這個題目,那個n還是我補上的。使用多個數組記錄列和對角線的情況,若皇后可在對角線上連成直線,則橫縱坐標之和、之差均相等。var d:array[1..20] of longint; a,b,c:array[-100..160] of 0..1; t,n,z:longint;PRocedure try(s:longint);var i:longint;begin if s>n then begin if z<>3 then begin inc(z); for i:=1 to n do write(d[i],' '); writeln; end; inc(t); exit; end; for i:=1 to n do if (a[i]=0)and(b[s-i]=0)and(c[s+i]=0) then begin d[s]:=i; a[i]:=1; b[s-i]:=1; c[s+i]:=1; try(s+1); a[i]:=0; b[s-i]:=0; c[s+i]:=0; end;end;begin readln(n); try(1); writeln(t);end.
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 曲沃县| 同江市| 蒙山县| 申扎县| 福建省| 福建省| 扬州市| 湖州市| 卢氏县| 昭苏县| 铜鼓县| 忻城县| 永泰县| 苏尼特左旗| 虞城县| 茶陵县| 芦山县| 黑龙江省| 荣昌县| 宣恩县| 礼泉县| 安多县| 上虞市| 胶南市| 开化县| 岱山县| 融水| 萨嘎县| 平和县| 澄城县| 石屏县| 临高县| 犍为县| 治多县| 廊坊市| 泰和县| 陆川县| 大关县| 曲松县| 株洲县| 博兴县|