分享
 
 
 

N皇后问题的回溯算法 ---- 一切为了速度

王朝other·作者佚名  2006-01-09
窄屏简体版  字體: |||超大  

#include<iostream.h>

const int n = 15 ; //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的斜线方向上是不是有皇后.

//之所以用全局变量,因全局数组元素值自动为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) { //如果当前列已经下完(找不到合法位置)

// cout<<"当前行是非法行,当前列棋子走完,没有合法位置,回溯上一列棋子"<<endl ;

// cin.get() ;

queen[cur] = -1 ; //当前列棋子置于准备状态

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<<"出现斜线相交,该位置不合法"<<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下测试

/*

斜线判断如下:

正斜率对应数组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即可知道该斜线上是否有其他棋子.

负斜率判断如下

负余率对应数姐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]数组,若为1,则该行有棋子.

*/

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有