青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

隨筆-48  評論-259  文章-1  trackbacks-0

一、8皇后問題的分析   

 

8皇后問題實際上很容易一般化為n-皇后問題,即要求找出在一個n*n棋盤上放置n個皇后并使其不能互相攻擊的所有方案。令(x1,x )表示一個解,其中x 是把第i個皇后放在第i行的列數。由于沒有兩個皇后可以放入同一列;因此這所有的xi將是截然不同的。那么應如何去測試兩個皇后是否在同一條斜角錢上呢? 

    如果設想:棋盤的方格像二維數組a(1:n,1:n)的下標那樣標記,那么可以看到,對于在同一條斜角線上的由左上方到右下方的每一個元素有相同的行一列值,同樣,在同一條斜角線上的由右上方到左下方的每一個元素則有相同的+列值。假設有兩個皇后被放置在(i,j)和(k,1)位置上,那么根據以上所述,僅當

        i-j=k-1或i+j=k+1

時,它們才在同一條斜角線上。將這兩個等式分別變換成

       j-1=i-k 和 j-1=k-i

因此,當且僅當|j一1|=|ik|時,兩個皇后在同一條斜角線上。

    過程Place(k)返回一個布爾值,當第k個皇后能放置于x(k)的當前值處時,這個返回值為真。這個過程測試兩種情況,即x(k)是否不同于前面x(1),x(k-1)的值以及在同一條斜角線上是否根本就沒有別的皇后。該過程的計算時間是

二、8皇后問題的算法  

 

[算法]: 可以放置一個新皇后嗎?   [動畫]

    procedure Place(k)

    //如果一個皇后能放在第k行和x(k)列,則返回.true;否則返回false。x是

    個全程數組,進入此過程時已置了k個值。abs(r)過程返回r的絕對值//

    global x(1:k);integer i;k

    iß1

    while i<k do

    if x(i)=x(k) //在同一列有兩個皇后//

    or abs(x(i)-x(k))=abs(i-k) //在同一條斜角線上//

    then return(false)

    endif

    ißi+1

    repeat

    return(true)

    end Place

使用過程Place來改進以上算法給出的一般回溯方法,可得出下面求n皇后問題正確解的算法。

   [算法]: n皇后問題的所有解   [動畫]

    procedure nqueens(n)

    //此過程使用回溯法求出在一個n*n棋盤上放置n個皇后,使其不能互相攻擊

    的所有可能位置//

    integer k,n,x(1:n)

    x(1)ß0;kß1 //k是當前行;x(k)是當前列//

    whilek>0 do //對所有的行執行以下語句//

    x(k)ßx(k)+1 //移到下一列//

    while x(k)n and not Place(k) do //此處能放這個皇后嗎/

    x(k)+x(k)+1

    repeat

    ifx(k)n //找到一個位置//

    then if k=n //是一個完整的解嗎//

    thenprint(x) //是,打印這個數組//

                  elsek<--k+1;x(k)+0 //轉向下一行//

    endif

    else kßk-1 "回溯"

    endif

    repeat

    end nqueens

    此時,讀者可能對于過程nqueens怎么會優于硬性處理感奇怪。原因是這樣的,如果硬

性要求一個8*8的棋盤安排出8塊位置,就有 種可能的方式,即要檢查將近4.4*10 個8元組。然而過程nqueens只允許把皇后放置在不同的行和列上,因此至多需要作81次檢

查,即至多只檢查40320個8元組。

可以用過程estimate來估算nqueens所生成的結點數。要指出的是,過程estimate所需要的假定也適用于nqueens,即,使用固定的限界函數且在檢索進行時函數不改變。另外,在狀態空間樹的同一級的所有結點都有相同的度。圖44.8顯示了由過程estimate求結點估計數所用的五個8x8棋盤。如同所要求的那樣,棋盤上每一個皇后的位置是隨機選取的。對于每種選擇方案,都記下了可以將一個皇后合法地放在各行中列的數目(即狀態樹的每一級沒受限的結點數)。它們都列在每個棋盤下方的向量中。向量后面的數字表示過程estimate由這些量值所產生的值。這五次試驗的平均值是1625。8皇后狀態空間樹的結點總數是

 因此不受限結點的估計數大約只是8皇后狀態空間樹的結點總數的2.34%。

[動畫]

posted on 2007-06-21 22:21 星夢情緣 閱讀(6706) 評論(5)  編輯 收藏 引用 所屬分類: 算法分析

評論:
# re: 經典算法(5)---8—皇后問題 2007-06-22 23:25 | pass86
記得以前學習的時候用了回溯的算法。  回復  更多評論
  
# re: 經典算法(5)---8—皇后問題 2007-06-22 23:45 | 星夢情緣
我有回溯算法的,不過沒發上來  回復  更多評論
  
# re: 經典算法(5)---8—皇后問題 2007-06-26 17:36 | 匿名
可以改進一下,用4個全局的數組分別存放8行、8列、兩種斜線各15條上是否已經放了皇后。 每放置或取走一個皇后,都改一下這四個數組。這樣判斷是否能放,4個條件就夠了,不用循環。  回復  更多評論
  
# re: 經典算法(5)---8—皇后問題 2007-12-13 15:28 | jenny
// 八皇后2.cpp : Defines the entry point for the console application.
//

#include "stdafx.h"
#include "stdio.h"
#include "iostream.h"
#include "math.h"
#define NUM 8 /*定義數組的大小*/
int x[NUM+1];
int place(int k)
{
int i=1;
while(i<k)
{
if(x[i]==x[k]||abs(x[i]-x[k])==abs(i-k))
return 0;
i++;
}
return 1;
}
void nqueens(int n)
{
int k;
int t;
int d=1;
x[1]=0;k=1;
int tt=n/2;
while(k>0&&k<=n)
{
x[k]=x[k]+1;
{ while(x[k]<=n&&!place(k))
x[k]=x[k]+1;
if(x[k]<=n)
{
if((k==n)&&(n%2==0))
{ cout<<"輸出皇后 {"<<d<<"} 隊列"<<endl;
d++;
for(int i=1;i<NUM+1;i++)
printf("%5d",x[i]);
cout<<endl;
}
else {k++;x[k]=0;}
}
else k--;
}
}
}
int main(int argc, char* argv[])
{
nqueens(NUM);
return 0;
}
  回復  更多評論
  
# re: 經典算法(5)---8—皇后問題 2008-08-31 17:22 | LM
學習,謝謝  回復  更多評論
  
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            欧美日韩在线播放三区| 亚洲第一伊人| 国产一区二区久久精品| 亚洲一二三区视频在线观看| 欧美成人国产va精品日本一级| 亚洲天天影视| 欧美视频在线视频| 亚洲视频大全| 日韩视频在线观看国产| 欧美日韩国产页| 亚洲色图制服丝袜| 中国女人久久久| 国产精品v片在线观看不卡| 亚洲午夜久久久久久尤物| 99国产精品久久久| 国产精品福利影院| 性欧美大战久久久久久久久| 亚洲天堂av在线免费| 国产精品久久久久久久久动漫| 亚洲一区二区三区四区五区午夜 | 亚洲高清av在线| 毛片av中文字幕一区二区| 亚洲国产精品视频一区| 亚洲激情亚洲| 国产精品美女xx| 久久久久久夜| 狼狼综合久久久久综合网| 日韩视频一区二区三区在线播放 | 欧美精品久久99久久在免费线| 亚洲精品一品区二品区三品区| 亚洲全黄一级网站| 国产精品久久久久毛片软件 | 91久久综合| 亚洲欧洲日韩在线| 欧美亚洲不卡| 久久久久久综合| 免费在线成人av| 亚洲综合视频一区| 久久精品国产精品亚洲| 亚洲破处大片| 亚洲男人第一av网站| 亚洲高清资源综合久久精品| 亚洲欧洲美洲综合色网| 国产精品麻豆成人av电影艾秋| 久久成人综合视频| 欧美激情一区二区三区蜜桃视频 | 久久精品首页| 欧美大片免费久久精品三p| 亚洲欧美国产毛片在线| 久久人人爽人人爽| 午夜国产不卡在线观看视频| 久久综合色88| 欧美主播一区二区三区| 欧美另类变人与禽xxxxx| 久久久九九九九| 欧美日韩一区二区三区在线看 | 久久激情视频| 亚洲图片在区色| 美女精品国产| 欧美中文字幕在线观看| 欧美日韩精品免费观看视频| 老妇喷水一区二区三区| 国产精品美女久久久久久久| 亚洲国产精品视频一区| 精东粉嫩av免费一区二区三区| 一区二区三区精品视频| 亚洲精品一区二区三区av| 欧美一区二区私人影院日本| 亚洲午夜久久久久久久久电影院| 免费观看成人鲁鲁鲁鲁鲁视频| 久久久91精品国产一区二区精品| 欧美午夜激情小视频| 亚洲国产精品va在线观看黑人| 国产一区观看| 亚洲欧美日韩精品| 亚洲一区在线免费| 欧美日本高清| 亚洲人成啪啪网站| 亚洲精品九九| 欧美v日韩v国产v| 欧美成人精品在线播放| 国产真实久久| 久久精品盗摄| 美女精品在线观看| 一区二区三区无毛| 久久精品免费| 免费成人毛片| 亚洲欧洲日产国产综合网| 老牛影视一区二区三区| 欧美freesex8一10精品| 亚洲国产91| 欧美国产另类| 亚洲美女精品久久| 久久综合99re88久久爱| 91久久嫩草影院一区二区| 国产香蕉97碰碰久久人人| 亚洲欧美另类在线| 久久久精品视频成人| 国模吧视频一区| 久久资源在线| 亚洲精品日韩在线| 亚洲欧美日韩中文视频| 国产欧美日韩视频| 久久精品视频在线观看| 欧美成人精品在线观看| 99re热这里只有精品免费视频| 欧美日韩情趣电影| 国产精品99久久久久久宅男| 欧美在线播放高清精品| 亚洲第一色在线| 欧美日产国产成人免费图片| 一区二区三区导航| 久久久青草婷婷精品综合日韩 | 欧美+亚洲+精品+三区| 亚洲精品永久免费| 国产精品国产三级国产aⅴ浪潮| 亚洲女女女同性video| 噜噜噜噜噜久久久久久91| 日韩视频三区| 国产日韩欧美一区二区| 欧美成人免费va影院高清| 一区二区三区欧美视频| 久久综合九色综合久99| 99精品福利视频| 国产午夜久久久久| 欧美不卡一区| 欧美亚洲专区| 99re8这里有精品热视频免费| 久久国产精品99久久久久久老狼| 亚洲国产99| 国产日韩专区| 欧美日韩国产高清视频| 久久精品伊人| 亚洲天天影视| 亚洲高清资源综合久久精品| 午夜免费电影一区在线观看| 亚洲激情电影在线| 国产亚洲精品自拍| 欧美日韩国产成人精品| 久久在线视频在线| 新67194成人永久网站| 亚洲人成网在线播放| 久久一区二区三区超碰国产精品| 亚洲午夜一区二区三区| 亚洲欧洲精品天堂一级| 国产一区二区三区高清| 欧美色大人视频| 免费日韩一区二区| 久久av一区二区| 亚洲一级二级| 一区二区三区黄色| 亚洲肉体裸体xxxx137| 欧美高清视频一二三区| 久久久亚洲综合| 午夜精品网站| 亚洲午夜免费视频| 亚洲最新合集| 日韩视频在线一区| 亚洲国产欧美日韩精品| 永久免费精品影视网站| 国产午夜精品一区二区三区欧美 | 国产精品日韩在线播放| 欧美日韩国产欧| 中文在线资源观看网站视频免费不卡| 欧美视频久久| 欧美国产高清| 另类av一区二区| 久久综合色影院| 久久九九精品99国产精品| 香蕉av777xxx色综合一区| 亚洲一区二区三区精品视频 | 欧美成人免费在线| 久久色中文字幕| 久久综合一区| 欧美成人午夜激情在线| 你懂的视频欧美| 欧美黄色日本| 欧美日韩一区二区国产| 欧美日韩一区二区高清| 国产精品分类| 国产无一区二区| 一区在线视频观看| 亚洲高清在线观看一区| 亚洲精品免费在线| 一区二区高清在线| 午夜一区在线| 久久亚洲一区二区| 欧美激情中文字幕在线| 亚洲精品国偷自产在线99热| 亚洲日本电影| 亚洲一区三区电影在线观看| 午夜视频在线观看一区| 久久久国产成人精品| 欧美成人四级电影| 欧美日韩中文字幕在线视频| 国产精品乱码人人做人人爱| 国语自产精品视频在线看抢先版结局| 极品av少妇一区二区| 亚洲美女av黄| 欧美一区免费视频|