#include <stdio.h>
#include <stdlib.h>
int count;
//遞歸法實(shí)現(xiàn)八皇后問題
//參數(shù)row表示起始行,參數(shù)n表示列數(shù)
//參數(shù)(*chess)[8]表示指向棋盤每一行的指針
int notdanger(int row,int j,int (*chess)[8]){
int i,k;
//判斷列方向
for(i=0;i<8;i++){
if(*(*(chess+i)+j)==1){//這一列已存在皇后
return 0;
}
}
//判斷左上方
for(i=row,k=j;i>=0&&k>=0;i--,k--){
if(*(*(chess+i)+k)==1){
return 0;
}
}
//判斷右下方
for(i=row,k=j;i<8&&k<8;i++,k++){
if(*(*(chess+i)+k)==1){
return 0;
}
}
//判斷左下方
for(i=row,k=j;i<8&&k>=0;i++,k--){
if(*(*(chess+i)+k)==1){
return 0;
}
}
//判斷右上方
for(i=row,k=j;i>=0&&k<8;i--,k++){
if(*(*(chess+i)+k)==1){
return 0;
}
}
return 1;
}
void eightqueen(int row,int n,int (*chess)[8]){
int chess2[8][8],i,j;
for(i=0;i<8;i++){
for(j=0;j<8;j++){
chess2[i][j]=chess[i][j];
}
}
if(row==8){
printf("第%d種:\n",++count);
for(i=0;i<8;i++){
for(j=0;j<8;j++){
printf("%d ",*(*(chess2+i)+j));
}
printf("\n");
}
}
else {
//判斷這個(gè)位置是否有危險(xiǎn)
//如果有危險(xiǎn),那繼續(xù)往下
for(j=0;j<n;j++){
if(notdanger(row,j,chess)){//判斷是否危險(xiǎn)
for(i=0;i<8;i++){
*(*(chess2+row)+i)=0;
}
*(*(chess2+row)+j)=1;
eightqueen(row+1,n,chess2);
}
}
}
}
int main()
{
int chess[8][8];
int i,j;
//初始化棋盤為0
for(i=0;i<8;i++){
for(j=0;j<8;j++){
chess[i][j]=0;
}
}
eightqueen(0,8,chess);//從第0行開始依次以行為單位遍歷
return 0;
}
c語(yǔ)言 遞歸實(shí)現(xiàn)八皇后算法
最后編輯于 :
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
- 文/潘曉璐 我一進(jìn)店門熙揍,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)职祷,“玉大人,你說(shuō)我怎么就攤上這事届囚∮邪穑” “怎么了?”我有些...
- 文/不壞的土叔 我叫張陵意系,是天一觀的道長(zhǎng)泥耀。 經(jīng)常有香客問我,道長(zhǎng)蛔添,這世上最難降的妖魔是什么痰催? 我笑而不...
- 正文 為了忘掉前任,我火速辦了婚禮迎瞧,結(jié)果婚禮上夸溶,老公的妹妹穿的比我還像新娘。我一直安慰自己夹攒,他們只是感情好蜘醋,可當(dāng)我...
- 文/花漫 我一把揭開白布胁塞。 她就那樣靜靜地躺著咏尝,像睡著了一般。 火紅的嫁衣襯著肌膚如雪啸罢。 梳的紋絲不亂的頭發(fā)上编检,一...
- 那天,我揣著相機(jī)與錄音扰才,去河邊找鬼允懂。 笑死,一個(gè)胖子當(dāng)著我的面吹牛衩匣,可吹牛的內(nèi)容都是我干的蕾总。 我是一名探鬼主播粥航,決...
- 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼生百!你這毒婦竟也來(lái)了递雀?” 一聲冷哼從身側(cè)響起,我...
- 序言:老撾萬(wàn)榮一對(duì)情侶失蹤蚀浆,失蹤者是張志新(化名)和其女友劉穎缀程,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體市俊,經(jīng)...
- 正文 獨(dú)居荒郊野嶺守林人離奇死亡杨凑,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
- 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了摆昧。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片撩满。...
- 正文 年R本政府宣布曼追,位于F島的核電站,受9級(jí)特大地震影響汉规,放射性物質(zhì)發(fā)生泄漏礼殊。R本人自食惡果不足惜,卻給世界環(huán)境...
- 文/蒙蒙 一针史、第九天 我趴在偏房一處隱蔽的房頂上張望晶伦。 院中可真熱鬧,春花似錦啄枕、人聲如沸婚陪。這莊子的主人今日做“春日...
- 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)泌参。三九已至,卻和暖如春常空,著一層夾襖步出監(jiān)牢的瞬間沽一,已是汗流浹背。 一陣腳步聲響...
- 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像蝗蛙,于是被迫代替她去往敵國(guó)和親蝇庭。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
推薦閱讀更多精彩內(nèi)容
- 八皇后算法介紹 知道國(guó)際象棋的朋友們應(yīng)該知道里面的皇后是最厲害的角色捡硅,她可以上下左右通吃遗契,和中國(guó)象棋里面的車(ju...
- 目錄[TOC] 問題分析: 相信八皇后規(guī)則的問題,大家都很熟悉病曾,接下來(lái)是如何分析回溯法的應(yīng)用牍蜂。回溯法與圖里面的深度...
- 八皇后問題問題描述:八皇后問題从绘,是一個(gè)古老而著名的問題僵井,是回溯算法的典型案例驳棱。該問題是國(guó)際西洋棋棋手馬克斯·貝瑟爾...
- 需要注意的是驻债,比如如下代碼: 為什么不是直接 stackk.Push(node);不是更方便嗎由于本人知識(shí)淺薄合呐,還...
- 這是以前畫的,大概用了小半年的時(shí)間把戴敦邦國(guó)畫水滸108將畫了一遍猖腕。 以后陸續(xù)再發(fā)吧谈息,這幾天沒畫,先打個(gè)卡。