c語(yǔ)言 遞歸實(shí)現(xiàn)八皇后算法

#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;  
}  
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末摇予,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子户矢,更是在濱河造成了極大的恐慌,老刑警劉巖丝格,帶你破解...
    沈念sama閱讀 219,490評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件唠梨,死亡現(xiàn)場(chǎng)離奇詭異算芯,居然都是意外死亡柒昏,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,581評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門熙揍,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)职祷,“玉大人,你說(shuō)我怎么就攤上這事届囚∮邪穑” “怎么了?”我有些...
    開封第一講書人閱讀 165,830評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵意系,是天一觀的道長(zhǎng)泥耀。 經(jīng)常有香客問我,道長(zhǎng)蛔添,這世上最難降的妖魔是什么痰催? 我笑而不...
    開封第一講書人閱讀 58,957評(píng)論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮迎瞧,結(jié)果婚禮上夸溶,老公的妹妹穿的比我還像新娘。我一直安慰自己夹攒,他們只是感情好蜘醋,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,974評(píng)論 6 393
  • 文/花漫 我一把揭開白布胁塞。 她就那樣靜靜地躺著咏尝,像睡著了一般。 火紅的嫁衣襯著肌膚如雪啸罢。 梳的紋絲不亂的頭發(fā)上编检,一...
    開封第一講書人閱讀 51,754評(píng)論 1 307
  • 那天,我揣著相機(jī)與錄音扰才,去河邊找鬼允懂。 笑死,一個(gè)胖子當(dāng)著我的面吹牛衩匣,可吹牛的內(nèi)容都是我干的蕾总。 我是一名探鬼主播粥航,決...
    沈念sama閱讀 40,464評(píng)論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼生百!你這毒婦竟也來(lái)了递雀?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,357評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤蚀浆,失蹤者是張志新(化名)和其女友劉穎缀程,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體市俊,經(jīng)...
    沈念sama閱讀 45,847評(píng)論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡杨凑,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,995評(píng)論 3 338
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了摆昧。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片撩满。...
    茶點(diǎn)故事閱讀 40,137評(píng)論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖绅你,靈堂內(nèi)的尸體忽然破棺而出鹦牛,到底是詐尸還是另有隱情,我是刑警寧澤勇吊,帶...
    沈念sama閱讀 35,819評(píng)論 5 346
  • 正文 年R本政府宣布曼追,位于F島的核電站,受9級(jí)特大地震影響汉规,放射性物質(zhì)發(fā)生泄漏礼殊。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,482評(píng)論 3 331
  • 文/蒙蒙 一针史、第九天 我趴在偏房一處隱蔽的房頂上張望晶伦。 院中可真熱鬧,春花似錦啄枕、人聲如沸婚陪。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,023評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)泌参。三九已至,卻和暖如春常空,著一層夾襖步出監(jiān)牢的瞬間沽一,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,149評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工漓糙, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留铣缠,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,409評(píng)論 3 373
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像蝗蛙,于是被迫代替她去往敵國(guó)和親蝇庭。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,086評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容