亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? n皇后.cpp

?? n皇后
?? CPP
字號:
#include<iostream.h>

const int n = 12 ; //15皇后問題.改動n可變成N皇后問題
const int n_sub = n - 1 ;
int queen[n] ;  //N個棋子.N對應每一列,如n=0的棋子只下在0列,1下1....類推
bool row[n] ;    //棋局的每一行是否有棋,有則為1,無為0 ;
bool passive[2*n-1] ;  //斜率為1的斜線方向上是不是有皇后
bool negative[2*n-1] ; //斜率為負1的斜線方向上是不是有皇后.
//之所以用全局變量,因全局數(shù)組元素值自動為0

int main()
{ 
 int cur = 0 ;//游標,當前移動的棋子(哪一列的棋子)
 bool flag = false ; //當前棋子位置是否合法
 queen[0] = -1 ;  //第0列棋子準備,因一開始移動的就是第0列棋子
 int count = 0 ; //一共有多少種下法 ;
 cout<<"============================Starting============================="<<endl ;

 while(cur>=0)
 {  
  while(cur>=0 && queen[cur]<n && !flag) //當還不確定當前位置是否可下 
  {
   queen[cur]++ ;
//   cout<<"第"<<cur<<"列棋子開始走在第"<<queen[cur]<<"行"<<endl ;
//   cin.get() ;
   if(queen[cur] >= n) { //如果當前列已經(jīng)下完(找不到合法位置)
//    cout<<"當前行是非法行,當前列棋子走完,沒有合法位置,回溯上一列棋子"<<endl ;
//    cin.get() ;
    queen[cur] = -1 ; //當前列棋子置于準備狀態(tài)
    cur-- ; //回溯到上一列的棋子
    if(cur>=0)  {
        row[queen[cur]] = false ; 
        passive[queen[cur] + cur] = false ;
           negative[n_sub + cur - queen[cur]] = false ;
    }
    //由于要移下一步,所以回溯棋子原位置所在行應該沒有棋子啦.置row[]為false  
   //并且棋子對應的斜線的標志位passive[cur]和negative[cur]也應該要設為false ;     
   }
   else { 
    //先判斷棋子所在行沒有棋子
    if(row[queen[cur]] == false)  { //當前行沒有棋子
//        cout<<"棋子"<<cur<<"所在行沒有其他棋子,正在檢查斜線"<<endl ;
        flag = true ; // 暫設為true,或與之前棋子斜交,則再設為false ;
     //以下檢查當前棋子是否與之前的棋子斜線相交
     if( passive[queen[cur] + cur] == true || negative[n_sub + cur - queen[cur]] == true)  {
      flag = false ;
//      cout<<"出現(xiàn)斜線相交,該位置不合法"<<endl ;
     }
     else     
      flag = true ;
     if(flag)  { //沒有斜交,位置合法
//         cout<<"斜線也沒有相交,該位置合法"<<endl ;
         if(cur == n-1)  //如果是最后一個棋子
      {
//          cout<<"棋子走完一輪,總走法加1"<<endl ;
          count++ ;  //總走法加一 ;
      }
         row[queen[cur]] = true ;// 當前行設為有棋子
      passive[queen[cur] + cur] = true ;//當前行正斜率方向有棋子
      negative[n_sub + cur - queen[cur]] = true ; //當前行負斜率方向上也有棋子
      cur++ ;
      if(cur >= n)  {
       cur-- ;
       row[queen[cur]] = false ; 
       passive[queen[cur] + cur] = false ;
             negative[n_sub + cur - queen[cur]] = false ;//原理同回溯
      }      
      flag = false ;     
     }
    }
   }//else
  }
 }
 cout<<n<<"皇后問題一共有"<<count<<"種解法"<<endl  ;
 return 0 ;
}

//計算15皇后用時1分鐘15秒
//把n改成16,測16皇后用時大約8分鐘
//以上測試在Barton 2000+,KingstonDDR400 256M下測試

/*

斜線判斷如下:


正斜率對應數(shù)組passive[2*n-1] ;
0    1    2    3.... .  n
1    2    3    4.....   n+1
2    3    4    5....   .n+2
3    4    5    6.....   n+3
....................
n-1 n    n+1 n+2...2*n-1 
利用行和列的坐標相加,即可得到其對應斜線對應的passive[i].再看一下passive[i]是否為1即可知道該斜線上是否有其他棋子.

負斜率判斷如下
負余率對應數(shù)姐negative[2*n-1]
n-1 n    n+1 n+2...2*n-1 
..............................
3    4    5    6....    n+3
2    3    4    5....   .n+2
1    2    3    4.....   n+1
0    1    2    3.... .  n
用棋子所在位置的橫坐標(cur)減去縱坐標(queen[cur]),再加上n-1,即可得到對應的
negative[i]數(shù)組,若為1,則該行有棋子.
*/

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成人美女在线观看| 99视频精品免费视频| 亚洲国产精品成人综合色在线婷婷| 91免费国产在线| 老汉av免费一区二区三区| 亚洲欧洲综合另类在线| 久久综合九色综合97婷婷女人 | 东方aⅴ免费观看久久av| 亚洲国产一区视频| 中文字幕在线播放不卡一区| 欧美一二三区在线| 一本色道a无线码一区v| 国产在线播放一区| 成人免费高清视频在线观看| 蜜臀va亚洲va欧美va天堂| 亚洲免费电影在线| 久久久久久久综合日本| 欧美精品v国产精品v日韩精品| 波多野结衣精品在线| 精品在线你懂的| 日本欧美肥老太交大片| 亚洲国产cao| 亚洲欧美偷拍另类a∨色屁股| 久久综合五月天婷婷伊人| 欧美精品一级二级三级| 色播五月激情综合网| 成人性生交大片免费看在线播放| 美女看a上一区| 天堂成人免费av电影一区| 伊人色综合久久天天人手人婷| 国产女人aaa级久久久级| 精品国产人成亚洲区| 4438x亚洲最大成人网| 欧美在线一区二区| 一本到一区二区三区| 成人av在线一区二区| 盗摄精品av一区二区三区| 激情六月婷婷综合| 久久99久久精品| 麻豆一区二区在线| 奇米色一区二区三区四区| 五月综合激情日本mⅴ| 亚洲成人三级小说| 午夜精品久久久久久久久| 亚洲成人黄色小说| 日韩经典中文字幕一区| 石原莉奈在线亚洲二区| 日本午夜一本久久久综合| 婷婷丁香久久五月婷婷| 日韩精品视频网站| 蜜桃精品视频在线| 精品一区二区三区在线观看国产 | 日本不卡123| 日本不卡一区二区| 韩国精品主播一区二区在线观看 | 欧美亚洲动漫制服丝袜| 欧美在线观看禁18| 欧美精品在线观看播放| 日韩欧美国产wwwww| 26uuu国产一区二区三区| 久久久精品中文字幕麻豆发布| 国产欧美精品一区| 亚洲视频在线观看一区| 亚洲国产精品一区二区久久恐怖片| 亚洲一区二区三区在线看| 日韩精品亚洲一区| 国产一区二区三区黄视频 | 国产盗摄一区二区三区| 成人高清免费观看| 欧美色电影在线| 精品电影一区二区| 国产精品福利一区| 亚洲电影中文字幕在线观看| 91免费国产在线| 欧美理论片在线| 久久品道一品道久久精品| 国产精品久久久久久久久搜平片 | 91国产免费观看| 日韩午夜精品视频| 国产精品午夜免费| 亚洲成a人片在线观看中文| 久久av中文字幕片| av激情综合网| 欧美一区二区精品在线| 国产精品午夜在线| 日韩电影在线观看电影| 国产精品18久久久久久vr| 色悠悠久久综合| 精品成a人在线观看| 亚洲精品国产无套在线观| 美女在线视频一区| 99久久er热在这里只有精品66| 在线综合视频播放| 国产精品久久福利| 美女高潮久久久| 91麻豆成人久久精品二区三区| 91精品国产欧美一区二区成人 | 国产精品久久久久久久久图文区| 亚洲一区二区三区四区的| 久久国产婷婷国产香蕉| 色婷婷av一区二区三区大白胸| 精品久久久久99| 亚洲国产日韩综合久久精品| 国产精品一区专区| 欧美剧情片在线观看| 国产精品网站在线观看| 男人的天堂久久精品| 91在线无精精品入口| 2014亚洲片线观看视频免费| 亚洲一区二区成人在线观看| 成人黄色大片在线观看| 欧美精品一区二区在线观看| 亚洲h精品动漫在线观看| www.亚洲免费av| 国产欧美一二三区| 久久97超碰国产精品超碰| 欧美久久一二三四区| 最近日韩中文字幕| 国产成人精品免费视频网站| 日韩欧美精品在线| 天涯成人国产亚洲精品一区av| 99国产欧美另类久久久精品| 国产农村妇女精品| 国产在线视频一区二区| 欧美一区二区三区免费| 视频精品一区二区| 欧美日韩精品免费| 一区二区三区精品在线| 色悠久久久久综合欧美99| 亚洲视频精选在线| 91在线小视频| 亚洲精品国产a久久久久久| 91免费视频大全| 一区二区三区中文字幕| 色一区在线观看| 日韩美女视频19| 91论坛在线播放| 一二三四社区欧美黄| 91黄色免费看| 亚洲午夜在线观看视频在线| 欧美视频一区在线| 日韩精品久久理论片| 欧美视频精品在线| 亚洲福利视频一区二区| 5月丁香婷婷综合| 日韩1区2区3区| 日韩欧美一区二区不卡| 色婷婷精品大视频在线蜜桃视频| 国产精品婷婷午夜在线观看| 99久久er热在这里只有精品15| 亚洲靠逼com| 欧美午夜一区二区三区免费大片| 亚洲成人久久影院| 51精品久久久久久久蜜臀| 免费成人av资源网| 久久日韩精品一区二区五区| 高清成人免费视频| 国产精品国模大尺度视频| 99精品视频在线观看| 亚洲综合色成人| 欧美一级一区二区| 国产精品一区二区免费不卡 | 国产精品高清亚洲| 欧美主播一区二区三区美女| 午夜精品成人在线| 久久蜜桃一区二区| av一区二区不卡| 亚洲gay无套男同| 久久精品水蜜桃av综合天堂| 99v久久综合狠狠综合久久| 亚洲一二三四久久| 精品区一区二区| 成av人片一区二区| 婷婷激情综合网| 国产欧美精品国产国产专区 | 精品免费日韩av| 成人免费的视频| 亚洲成人资源在线| 久久久久久99精品| 色偷偷成人一区二区三区91| 日本午夜精品一区二区三区电影| 久久久久久免费网| 欧美性做爰猛烈叫床潮| 经典三级一区二区| 亚洲美女精品一区| 精品99久久久久久| 日本大香伊一区二区三区| 免费xxxx性欧美18vr| 国产精品国产三级国产普通话99| 欧美日韩亚洲综合| 岛国av在线一区| 日韩国产成人精品| 一区二区中文字幕在线| 欧美一区二区在线免费观看| 国产99久久久久| 日韩黄色在线观看| 亚洲色图制服诱惑| 精品国产乱码久久久久久图片| 色婷婷综合五月| 国产盗摄一区二区三区|