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

逛奔的蝸牛

我不聰明,但我會(huì)很努力

   ::  :: 新隨筆 ::  ::  :: 管理 ::

#include <iostream>
#include <cstdio>
#include <ctime>
#include <cmath>

using namespace std;

void queen(int** array, int row, FILE* fp);
bool isAvailable(int** array, int y, int x);
bool isResult(int** array);

int main(int arg, char** argv) {
        int** array;
        
        // 分配空間
        array = new int*[8];
        for (int i = 0; i < 8; i++) {
                array[i] = new int[8];
        }
        
        // 初始化皇后狀態(tài)
        for (int i = 0; i < 8; i++) {
                for (int j = 0; j < 8; j++) {
                        array[i][j] = 0;
                }
        }
        
        FILE* fp = fopen("data.txt", "w");
        queen(array, 0, fp);
        fclose(fp);
        
        // 釋放空間
        for (int i = 0; i < 8; i++) {
                delete[] array[i];
        }
        delete array;
        array = NULL;

        return 0;
}

void queen(int** array, int row, FILE* fp) {
        static int size = 1;
        if (row > 7) {
                return;
        }
        for (int j = 0; j < 8; j++) {
                // 如果合法
                if (isAvailable(array, row, j)) {
                        array[row][j] = 1;
                        
                        // 當(dāng)前位置合法,賦值后,進(jìn)入下一行
                        queen(array, row + 1, fp);

                        // 如果退回來后是結(jié)果,則打印出來
                        if (isResult(array)) {
                                // 把結(jié)果寫入文件
                                fputc('\n', fp);
                                fputs("***********************************", fp);
                                fprintf(fp, " %d ", size++);
                                fputs("***********************************", fp);
                                fputc('\n', fp);
                                for (int m = 0; m < 8; m++) {
                                        for (int n = 0; n < 8; n++) {
                                                if (array[m][n] == 1) {
                                                        fputc('#', fp);
                                                        fputc(' ', fp);
                                                        fputc(' ', fp);
                                                } else {
                                                        fputc('O', fp);
                                                        fputc(' ', fp);
                                                        fputc(' ', fp);
                                                }
                                        }
                                        fputc('\n', fp); 
                                }

                        }
                        array[row][j] = 0;

                }
        }
}

bool isAvailable(int** array, int row, int column) { // 第row行,column列
        int i, j;

        // 檢查row行
        for (i = 0; i < 8; i++) {
                if (array[row][i] != 0) {
                        return false;
                }
        }

        // 檢columnx列
        for (j = 0; j < 8; j++) {
                if (array[j][column] != 0) {
                        return false;
                }
        }

        // 檢查對(duì)角向左上
        i = row;
        j = column;
        while (i >= 0 && j >= 0) {
                if (array[i][j] != 0) {
                        return false;
                }
                i--;
                j--;
        }

        // 檢查對(duì)角向右上
        i = row;
        j = column;
        while (i >= 0 && j < 8) {
                if (array[i][j] != 0) {
                        return false;
                }
                i--;
                j++;
        }

        // 檢查對(duì)角向左下
        i = row;
        j = column;
        while (i < 8 && j >= 0) {
                if (array[i][j] != 0) {
                        return false;
                }
                i++;
                j--;
        }

        // 檢查對(duì)角向右下
        i = row;
        j = column;
        while (i < 8 && j < 8) {
                if (array[i][j] != 0) {
                        return false;
                }
                i++;
                j++;
        }

        return true;
}

bool isResult(int** array) {
        int size = 0; // 皇后個(gè)數(shù)

        // 統(tǒng)計(jì)皇后個(gè)數(shù)
        for (int i = 0; i < 8; i++) {
                for (int j = 0; j < 8; j++) {
                        if (array[i][j] != 0) {
                                size++;
                        }
                }
        }

        // 沒有8?jìng)€(gè)皇后,說明不是結(jié)果

       // 有8個(gè)皇后,因?yàn)槊總€(gè)皇后的放置都是在合法位置, 所以只需要簡單的計(jì)算皇后個(gè)數(shù)就知道是不是結(jié)果.
        if (size != 8) {
                return false;
        }

        return true;
}

posted on 2010-12-17 17:51 逛奔的蝸牛 閱讀(417) 評(píng)論(0)  編輯 收藏 引用 所屬分類: C/C++
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美国产日韩在线| 91久久国产自产拍夜夜嗨| 亚洲自拍偷拍色片视频| 亚洲一区精彩视频| 亚洲男女毛片无遮挡| 亚洲欧美清纯在线制服| 欧美一级久久| 久久视频精品在线| 欧美国产日韩在线观看| 欧美肉体xxxx裸体137大胆| 国产精品高清在线观看| 国产日韩欧美中文在线播放| 国产一区二区三区无遮挡| 在线观看欧美一区| 一本色道久久88综合亚洲精品ⅰ| 一本色道久久综合亚洲91| 午夜在线电影亚洲一区| 老司机免费视频一区二区| 亚洲国产欧美一区| 一区二区三区 在线观看视频| 亚洲欧美日韩精品综合在线观看| 久久久蜜桃一区二区人| 欧美日韩一区国产| 国精产品99永久一区一区| 亚洲国产日韩欧美在线图片| 一区二区三区毛片| 免费精品99久久国产综合精品| 亚洲伦理在线观看| 美女国产精品| 国产在线乱码一区二区三区| 在线视频你懂得一区 | 久久精品亚洲精品| 亚洲激情网址| 久久精品一级爱片| 国产精品每日更新| 一区二区三区不卡视频在线观看| 久久久精品欧美丰满| 一本大道久久a久久精品综合| 久久综合电影一区| 国产一区二区丝袜高跟鞋图片| 一区二区三区三区在线| 国产精品美女久久久久久久 | 亚洲精品在线电影| 久久一区二区三区超碰国产精品| 国产精自产拍久久久久久| 一区二区三区久久精品| 亚洲国产黄色片| 久久综合狠狠综合久久综合88| 国产亚洲成av人片在线观看桃| 亚洲欧美国产一区二区三区| 99av国产精品欲麻豆| 欧美日韩国产123区| 日韩一级黄色大片| 亚洲精品一区二区三| 欧美激情91| 99国产精品久久久久老师| 亚洲福利久久| 欧美大片免费久久精品三p| 亚洲国产乱码最新视频| 欧美激情第9页| 欧美jjzz| 亚洲美女色禁图| 亚洲毛片在线观看.| 欧美精品亚洲精品| 一区二区三区|亚洲午夜| 亚洲另类春色国产| 国产精品久久久久三级| 欧美在现视频| 久久av二区| 亚洲激情影视| 99精品国产99久久久久久福利| 欧美性开放视频| 欧美一级久久久久久久大片| 欧美在线一二三四区| 亚洲国产精品久久久久秋霞不卡 | 欧美在线免费播放| 在线观看的日韩av| 亚洲精品国产系列| 国产欧美日本一区视频| 久久精品一区二区三区四区| 久久久久久久999| 一本一本a久久| 亚洲欧美日韩在线| 亚洲国产精品国自产拍av秋霞| 亚洲精品国产品国语在线app| 国产精品视频九色porn| 欧美/亚洲一区| 国产精品久久久久77777| 开元免费观看欧美电视剧网站| 欧美国产高潮xxxx1819| 亚洲免费在线视频| 老司机一区二区三区| 亚洲天堂男人| 久久亚洲精选| 欧美一级淫片aaaaaaa视频| 每日更新成人在线视频| 亚洲欧美日韩精品一区二区| 久久在线视频在线| 一本一本久久| 美女图片一区二区| 亚洲女同精品视频| 欧美成人免费视频| 久久精品网址| 国产精品国产a| 亚洲日本视频| 影音先锋日韩精品| 亚洲一级黄色片| 日韩视频免费观看高清在线视频| 性欧美长视频| 亚洲欧美日韩视频一区| 欧美精品 国产精品| 麻豆精品在线视频| 国产日韩一区在线| 亚洲午夜一区二区| 亚洲少妇在线| 欧美大片第1页| 欧美大片一区二区| 玉米视频成人免费看| 欧美一区二区三区四区夜夜大片| 亚洲一区二区三区四区视频| 欧美黄色视屏| 亚洲人成网站999久久久综合| 在线观看欧美黄色| 久久免费视频这里只有精品| 久久久久成人精品| 国产日本欧美一区二区三区| 亚洲视频精品| 亚洲欧美在线磁力| 国产精品欧美日韩一区二区| 一区二区国产在线观看| 在线视频日本亚洲性| 欧美日韩国产在线播放网站| 亚洲国产综合在线看不卡| 亚洲欧洲一区二区三区久久| 久久综合电影| 最新亚洲激情| 一区二区欧美激情| 欧美性开放视频| 亚洲一区二区三区中文字幕在线| 亚洲欧美视频一区| 国产日韩精品一区观看| 欧美一区二区三区视频| 久久久久久久999| 国产亚洲精品成人av久久ww| 欧美一区二区三区免费视频| 久久久久久久高潮| 激情综合激情| 欧美国产日韩二区| 99re在线精品| 午夜久久资源| 国语自产精品视频在线看8查询8| 久久精品人人爽| 亚洲国产二区| 亚洲你懂的在线视频| 国产亚洲精品福利| 男女精品视频| 亚洲视频一区二区在线观看| 午夜在线电影亚洲一区| 国产一区二区三区在线观看免费| 久久噜噜噜精品国产亚洲综合 | 另类av导航| 一本色道久久88亚洲综合88| 国产精品久久中文| 久久免费视频在线观看| 日韩亚洲视频| 蜜桃av一区二区| 欧美v日韩v国产v| 亚洲久久成人| 国产乱子伦一区二区三区国色天香| 亚洲一区视频在线观看视频| 久久久噜噜噜久久中文字幕色伊伊| 亚洲国产乱码最新视频| 国产精品久久久久9999| 久久精品视频在线看| 亚洲精品孕妇| 欧美88av| 欧美一区二区三区在线播放| 91久久极品少妇xxxxⅹ软件| 国产精品啊啊啊| 麻豆精品网站| 欧美一区二区三区免费观看视频 | 久久亚洲精品一区| 亚洲欧美激情诱惑| 亚洲国产日韩美| 国产亚洲精品一区二区| 欧美日韩精品一二三区| 久久野战av| 午夜宅男久久久| 一级日韩一区在线观看| 亚洲福利av| 欧美大片在线观看| 久久资源av| 久久精品动漫| 欧美一区二区国产| 亚洲一区二区视频在线观看| 亚洲人成网站在线播| 在线观看国产一区二区| 国内精品视频在线观看| 国产无一区二区| 国产免费一区二区三区香蕉精|