中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

C++騎士游歷問題的示例分析

發布時間:2022-03-04 09:56:24 來源:億速云 閱讀:229 作者:小新 欄目:開發技術

這篇文章主要介紹了C++騎士游歷問題的示例分析,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

騎士游歷問題:在國際棋盤上使一個騎士遍歷所有的格子一遍且僅一遍,對于任意給定的頂點,輸出一條符合上述要求的路徑

解題思路:

這是一道經典的遍歷問題(DFS),由于題目要求遍歷全部,那么肯定要做標記,因此立馬想到DFS深度優先算法。具體思路如下:

①了解國際象棋以及國際象棋騎士的走法

國際象棋和中國象棋,大同小異,畢竟中國象棋是老祖先。國際象棋棋子放在格子中,中國象棋放在點上,且國際象棋有64個格子。國際象棋的騎士和中國象棋的馬功能相當,都可以走八個方位。走法是走“日”字,或英文字母大寫的“L”形:即先向左(或右)走1格,再向上(或下)走2格;或先向左(或右)走2格,再向上(或下)走1格。與中國象棋的馬不同,國際象棋的馬可以跳過路上的其他棋子,不受拐腳的限制。
解題需要我們可以把格子抽象成一個點,那么國際象棋的騎士走法就是一個日字。

C++騎士游歷問題的示例分析

②設置標記

初始化數組,讓每個元素初始化為0,并且初始化一個記錄騎士遍歷次數的cal也為0

int cal = 0; //統計走的順序
//初始化為0
int chress[8][8] =           
{
    0, 0, 0, 0, 0, 0, 0, 0,
    0, 0, 0, 0, 0, 0, 0, 0,
    0, 0, 0, 0, 0, 0, 0, 0,
    0, 0, 0, 0, 0, 0, 0, 0,
    0, 0, 0, 0, 0, 0, 0, 0,
    0, 0, 0, 0, 0, 0, 0, 0,
    0, 0, 0, 0, 0, 0, 0, 0,
    0, 0, 0, 0, 0, 0, 0, 0
};

③判斷是否超界和是否被訪問

bool ifOut(int x, int y)  //判斷是否出界
{
    if (x >= 0 && x <= 7 && y >= 0 && y <= 7)
        return false;
    else
        return true;
}
bool ifVisited(int x, int y) //判斷是否被訪問
{
    if (chress[x][y] != 0)
        return true;
    else
        return false;
}

④遞歸主體

void dfs(int x,int y)
{    
    if (cal == 64) //如果遍歷完則退出棋盤一共64個位置
        return;
    if (!ifVisited(x, y) && !ifOut(x, y)) //如果沒有被訪問且沒有出界 則訪問
    {
        cal++;   
        chress[x][y] = cal; //做標記
        dfs(x + 2, y + 1);    //騎士走法有八個方位,故八個 方位都遍歷
        dfs(x - 2, y - 1);   //八個遞歸的順序可以改,順序不一樣,結果不一樣
        dfs(x + 2, y - 1);    
        dfs(x - 2, y + 1);    
        dfs(x - 1, y - 2);  
        dfs(x + 1, y - 2);    
        dfs(x + 1, y + 2);    
        dfs(x - 1, y + 2);  
        return;
    }
    else  //else其中包括已經被訪問了,和沒有被訪問且在界外的
        return;
}

⑤總代碼如下(編譯器vs2013)

#include"stdafx.h"
#include<iostream>
#include<iomanip>
using namespace std;
int cal = 0; //統計走的順序
//棋盤初始化為0做標記
int chress[8][8] =           
{
    0, 0, 0, 0, 0, 0, 0, 0,
    0, 0, 0, 0, 0, 0, 0, 0,
    0, 0, 0, 0, 0, 0, 0, 0,
    0, 0, 0, 0, 0, 0, 0, 0,
    0, 0, 0, 0, 0, 0, 0, 0,
    0, 0, 0, 0, 0, 0, 0, 0,
    0, 0, 0, 0, 0, 0, 0, 0,
    0, 0, 0, 0, 0, 0, 0, 0
};

bool ifOut(int x, int y)  //判斷是否出界
{
    if (x >= 0 && x <= 7 && y >= 0 && y <= 7)
        return false;
    else
        return true;
}
bool ifVisited(int x, int y) //判斷是否已經被訪問
{
    if (chress[x][y] != 0)
        return true;
    else
        return false;
}
void dfs(int x,int y)
{    
    if (cal == 64) //如果遍歷完則退出棋盤一共64個位置
        return;
    if (!ifVisited(x, y) && !ifOut(x, y)) //如果沒有被訪問且沒有出界 則訪問
    {
        cal++;   
        chress[x][y] = cal; //做標記
        dfs(x + 2, y + 1);    //騎士走法有八個方位,故八個 方位都遍歷
        dfs(x - 2, y - 1);  //八個遞歸的順序可以改,順序不一樣,結果不一樣 
        dfs(x + 2, y - 1);    
        dfs(x - 2, y + 1);    
        dfs(x - 1, y - 2);  
        dfs(x + 1, y - 2);    
        dfs(x + 1, y + 2);    
        dfs(x - 1, y + 2);  
        return;
    }
    else  //出界了則退出return
        return;

}
int main()
{    
    int x, y;
    cout << "請輸入騎士初始的位置:";
    while (1)
    {
        cin >> x >> y;    //輸入坐標
        if (x > 7 || x<0 || y> 7 || y < 0)
            cout << "初始位置輸入錯誤請重新輸入" << endl;
        else
            break;
    }
    dfs(x,y);
    for (int i = 0; i < 8; i++)  //輸出打印測試
    {
        for (int j = 0; j < 8; j++)
            cout << setw(2)<<chress[i][j]<<"  ";
        cout << endl;
    }
    return 0;
}

⑥測試截圖:

C++騎士游歷問題的示例分析

C++騎士游歷問題的示例分析

C++騎士游歷問題的示例分析

C++騎士游歷問題的示例分析

感謝你能夠認真閱讀完這篇文章,希望小編分享的“C++騎士游歷問題的示例分析”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,更多相關知識等著你來學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

c++
AI

长宁县| 博客| 天长市| 井陉县| 中西区| 汉源县| 宝丰县| 叙永县| 永靖县| 肥城市| 辽宁省| 崇州市| 延长县| 青铜峡市| 缙云县| 松溪县| 塘沽区| 南开区| 扎鲁特旗| 永新县| 陈巴尔虎旗| 临猗县| 宜丰县| 清流县| 甘孜| 祥云县| 象州县| 永春县| 游戏| 乐昌市| 辽宁省| 临沧市| 淳安县| 甘洛县| 青田县| 眉山市| 娱乐| 丰县| 尉氏县| 甘孜县| 同德县|