欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C++實現(xiàn)馬踏棋盤(騎士周游)

 更新時間:2022年02月15日 11:41:10   作者:lld951027  
這篇文章主要為大家詳細介紹了C++實現(xiàn)馬踏棋盤,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

馬踏棋盤,用1枚馬走遍棋盤。我用一個二維數(shù)組記錄模擬的整個路徑,x為列,y為行,以順時針的方式尋找下一格,算法比較簡單,就通過遞歸和循環(huán)回溯即可,就是如果是8*8的數(shù)組,最壞可能執(zhí)行8^(x*y)次,耗時長到懷疑人生。

#include<iostream>
#define X 5
#define Y 5
?
void ShowResult();
using namespace std;
?
int chess[Y][X]={
?? ?0
};
int counter=0;
?
int Next(int* x,int* y,int where){
?
?? ?switch(where){
?? ??? ?case 0:
?? ??? ??? ?if(*x+1<X&&*y-2>=0&&chess[*y-2][*x+1]==0){
?? ??? ??? ??? ?*x+=1;
?? ??? ??? ??? ?*y-=2;
?? ??? ??? ??? ?return 1;
?? ??? ??? ?}
?? ??? ??? ?break;
?? ??? ?case 1:
?? ??? ??? ?if(*x+2<X&&*y-1>=0&&chess[*y-1][*x+2]==0){
?? ??? ??? ??? ?*x+=2;
?? ??? ??? ??? ?*y-=1;
?? ??? ??? ??? ?return 1;
?? ??? ??? ?}
?? ??? ??? ?break;
?? ??? ?case 2:
?? ??? ??? ?if(*x+2<X&&*y+1<Y&&chess[*y+1][*x+2]==0){
?? ??? ??? ??? ?*x+=2;
?? ??? ??? ??? ?*y+=1;
?? ??? ??? ??? ?return 1;
?? ??? ??? ?}
?? ??? ??? ?break;
?? ??? ?case 3:
?? ??? ??? ?if(*x+1<X&&*y+2<Y&&chess[*y+2][*x+1]==0){
?? ??? ??? ??? ?*x+=1;
?? ??? ??? ??? ?*y+=2;
?? ??? ??? ??? ?return 1;
?? ??? ??? ?}
?? ??? ??? ?break;
?? ??? ?case 4:
?? ??? ??? ?if(*x-1>=0&&*y+2<Y&&chess[*y+2][*x-1]==0){
?? ??? ??? ??? ?*x-=1;
?? ??? ??? ??? ?*y+=2;
?? ??? ??? ??? ?return 1;
?? ??? ??? ?}
?? ??? ??? ?break;
?? ??? ?case 5:
?? ??? ??? ?if(*x-2>=0&&*y+1<Y&&chess[*y+1][*x-2]==0){
?? ??? ??? ??? ?*x-=2;
?? ??? ??? ??? ?*y+=1;
?? ??? ??? ??? ?return 1;
?? ??? ??? ?}
?? ??? ??? ?break;
?? ??? ?case 6:
?? ??? ??? ?if(*x-2>=0&&*y-1>=0&&chess[*y-1][*x-2]==0){
?? ??? ??? ??? ?*x-=2;
?? ??? ??? ??? ?*y-=1;
?? ??? ??? ??? ?return 1;
?? ??? ??? ?}
?? ??? ??? ?break;
?? ??? ?case 7:
?? ??? ??? ?if(*x-1>=0&&*y-2>=0&&chess[*y-2][*x-1]==0){
?? ??? ??? ??? ?*x-=1;
?? ??? ??? ??? ?*y-=2;
?? ??? ??? ??? ?return 1;
?? ??? ??? ?}
?? ??? ??? ?break;
?? ?}
?? ?return 0;
}
?
int Explore(int x,int y){
?? ?int x1=x;
?? ?int y1=y;
?? ?int flag;
?? ?int where=0;
?? ?
?
?? ?counter++;
?? ?chess[y][x]=counter;
?? ?
?
?? ?if(counter==X*Y){
?? ??? ?return 1;
?? ?}
?? ?
?? ?
?? ?
?? ?flag=Next(&x1,&y1,where);
?? ?while(flag==0&&where<7){
?? ??? ?where++;
?? ??? ?flag=Next(&x1,&y1,where);
?? ?}
?? ?
?? ?
?? ?while(flag){
?? ??? ?if(Explore(x1,y1)==1){
?? ??? ??? ?return 1;
?? ??? ?}
?? ??? ?else{
?? ??? ??? ?x1=x;
?? ??? ??? ?y1=y;
?? ??? ??? ?where++;
?? ??? ??? ?flag=Next(&x1,&y1,where);
?? ??? ??? ?while(flag==0&&where<7){
?? ??? ??? ??? ?where++;
?? ??? ??? ??? ?flag=Next(&x1,&y1,where);
?? ??? ??? ?}
?? ??? ?}
?? ?}
?? ?if(flag==0){
?? ??? ?chess[y][x]=0;
?? ??? ?counter--;
?? ?}
?? ?return 0;
}
?
void ShowResult(){
?? ?
?? ?for(int i=0;i<Y;i++){
?? ??? ?for(int j=0;j<X;j++){
?? ??? ??? ?cout.width(4);
?? ??? ??? ?cout<<chess[i][j]<<' ';
?? ??? ?}
?? ??? ?cout<<endl;
?? ?}
?? ?cout<<endl;
}
?
int main(){
?? ?int start=clock();
?? ?int result=Explore(2,1);
?? ?int end=clock();
?? ?if(result){
?? ??? ?ShowResult();?? ??? ?
?? ?}
?? ?else{
?? ??? ?cout<<"have no path!"<<endl;?
?? ?}
?
?? ?cout<<"spend time:"<<(end-start)/CLOCKS_PER_SEC<<" s"<<endl;
?? ?return 0;
}

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • C語言版的三子棋游戲

    C語言版的三子棋游戲

    這篇文章主要為大家詳細介紹了C語言版的三子棋游戲,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-08-08
  • openCV中meanshift算法查找目標的實現(xiàn)

    openCV中meanshift算法查找目標的實現(xiàn)

    本文主要介紹了openCV中meanshift算法查找目標的實現(xiàn),文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-11-11
  • C++實現(xiàn)LeetCode(170.兩數(shù)之和之三 - 數(shù)據(jù)結(jié)構(gòu)設(shè)計)

    C++實現(xiàn)LeetCode(170.兩數(shù)之和之三 - 數(shù)據(jù)結(jié)構(gòu)設(shè)計)

    這篇文章主要介紹了C++實現(xiàn)LeetCode(170.兩數(shù)之和之三 - 數(shù)據(jù)結(jié)構(gòu)設(shè)計),本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下
    2021-08-08
  • C語言實現(xiàn)動態(tài)鏈表的示例代碼

    C語言實現(xiàn)動態(tài)鏈表的示例代碼

    本文主要介紹了C語言實現(xiàn)動態(tài)鏈表的示例代碼,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-05-05
  • C/C++實現(xiàn)磁盤相關(guān)操作的示例代碼

    C/C++實現(xiàn)磁盤相關(guān)操作的示例代碼

    這篇文章主要為大家詳細介紹了C/C++如何實現(xiàn)磁盤相關(guān)操作,例如遍歷磁盤容量、實現(xiàn)磁盤格式化、移除指定磁盤等,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2023-11-11
  • C++編譯報錯:||error: ld returned 1 exit status|的解決

    C++編譯報錯:||error: ld returned 1 exit 

    這篇文章主要介紹了C++編譯報錯:||error: ld returned 1 exit status|的解決方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-01-01
  • C語言實現(xiàn)單鏈表的快速排序算法

    C語言實現(xiàn)單鏈表的快速排序算法

    大家好,本篇文章主要講的是C語言實現(xiàn)單鏈表的快速排序算法,感興趣的同學(xué)趕快來看一看吧,對你有幫助的話記得收藏一下
    2022-01-01
  • MongoDB?C?驅(qū)動程序安裝(libmongoc)?和?BSON?庫(libbson)方法

    MongoDB?C?驅(qū)動程序安裝(libmongoc)?和?BSON?庫(libbson)方法

    這篇文章主要介紹了安裝?MongoDB?C?驅(qū)動程序?(libmongoc)?和?BSON?庫?(libbson),本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-09-09
  • C語言實現(xiàn)簡單推箱子小游戲

    C語言實現(xiàn)簡單推箱子小游戲

    這篇文章主要為大家詳細介紹了C語言實現(xiàn)推箱子小游戲,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-11-11
  • Qt Design Studio安裝圖文教程

    Qt Design Studio安裝圖文教程

    本文主要介紹了Qt Design Studio安裝圖文教程,文中通過圖文介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-02-02

最新評論