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

C語言實現(xiàn)走迷宮

 更新時間:2020年07月22日 17:10:08   作者:回城之光  
這篇文章主要為大家詳細介紹了C語言實現(xiàn)走迷宮,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

本文實例為大家分享了C語言實現(xiàn)走迷宮的具體代碼,供大家參考,具體內(nèi)容如下

描述

給一張個迷宮,問能否從起點走到終點,只能往上下左右走,不能斜著走

輸入

多組測試數(shù)據(jù),每組第一行兩個正整數(shù),分別為n和m

表示n這個迷宮有n行m列(0<n,m<10)

接著是n行m列,

'#'表示路

‘*'表示墻

‘S'表示起點

‘T'表示終點

輸出

每組測試數(shù)據(jù)輸出一個結(jié)果,如果能從S走到T,輸出“YES”,否則輸出“NO”

輸入樣例:

2 2
S*
#T
3 3
S*#
#T
##

輸出樣例:

YES
NO

有兩種方法可以解決這個問題

第一種深度優(yōu)先搜索:站在入口,考慮自己下一步可以走哪里,走到下一個位置后,再考慮下一步怎么走,一直走下去,直到?jīng)]有路,然后再返回最近的一個岔路口,選其它任一條沒試過的路,如果不能走,再嘗試其他的路,直到這個岔路口的路全部試完,再回到上一個路口,看是否能走到出口,相當于一條路走到黑

#include<bits/stdc++.h>

using namespace std;
char a[20][20];  //存儲迷宮字符數(shù)組
int flag,m,n;
int sdep_x[4]={-1,1,0,0},sdep_y[4]={0,0,-1,1};//控制上下左右方向
int vis[20][20]; //標記走過的路
void dfs(int x,int y)
{
 vis[x][y]=1; //代表被標記過了
 if(a[x][y]=='T') //找到出口
 {
  flag=1;
  return;
 }
  for(int i=0;i<4;i++) //搜索路徑
  {
   int h=x+sdep_x[i];
   int l=y+sdep_y[i];
   if(a[h][l]!='*'&&!vis[h][l]&&h>=0&&h<n&&l>=0&&l<m)//搜索路徑的條件
   {
    dfs(h,l);
   }
  }
}

int main()
{
 while(cin>>n>>m)
 {
  memset(vis,0,sizeof(vis));//初始化數(shù)組
  flag=0;
  int f,g;
  for(int i=0;i<n;i++)
   for(int j=0;j<m;j++) 
    cin>>a[i][j];
  for(int i=0;i<n;i++)
   for(int j=0;j<m;j++)
   {
    if(a[i][j]=='S')//先找到路口
    {
     f=i;
     g=j;
    }
   }
  dfs(f,g);
  if(flag)
   cout<<"YES"<<endl;
  else
   cout<<"NO"<<endl;
 }
 return 0;
}

第二種方法廣度優(yōu)先搜索:這一步之后,把接下來一步的所有路都列出來,在之后的所有擴展之中,在以一個為下一步,再將所有的該步可以到達的下一步,全部列舉出來,再將第二步的其他選擇中的每一步,都一一做擴展,每次擴展,都要檢查所擴展的地方有沒有到達搜索的要求。
可以定義一個隊列,將擴展的點位置保存在隊列,將擴展完畢的點出隊

#include<bits/stdc++.h>
using namespace std;
int vis[20][20];
char a[20][20];
int n,m;
int step_x[4]={-1,1,0,0},step_y[4]={0,0,-1,1};
struct data//定義一個結(jié)構(gòu)體,里面包含x,y成員                                                         
{
 int x;
 int y;
};
data s,p;//定義兩個結(jié)構(gòu)體變量
queue<data>q;//定義一個隊列q
int BFS()
{
 while(!q.empty())//當隊列不為空時
 {
  p=q.front();//返回隊列的第一個元素
  vis[p.x][p.y]=1;
  q.pop();//刪除隊列中最靠前的元素
  if(a[p.x][p.y]=='T')//如果找到出口
   return 1;
  else
  {
   for(int i=0;i<4;i++)
   {
    s.x=p.x+step_x[i];
    s.y=p.y+step_y[i];
    if(s.x>=0&&s.x<n&&s.y>=0&&s.y<m&&!vis[s.x][s.y]&&a[s.x][s.y]!='*')//搜索條件
     q.push(s);//將擴展的點的位置存入隊尾
   }
  }
 }
 return 0;
}
int main()
{
 while(cin>>n>>m)
 {
  while(!q.empty())
  {
   q.pop();//清空隊列中的元素
  }
  for(int i=0;i<n;i++)
   for(int j=0;j<m;j++)
   cin>>a[i][j];
   for(int i=0;i<n;i++)
   {
   for(int j=0;j<m;j++)
   {
    vis[i][j]=0;
    if(a[i][j]=='S')
    {
     s.x=i;
     s.y=j;
     q.push(s);//將路口的位置保存在隊尾
    }
   }
   }
   if(BFS())
   cout<<"YES"<<endl;
   else
   cout<<"NO"<<endl;

 }
 return 0;
}

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

相關(guān)文章

  • C++ auto類型說明符

    C++ auto類型說明符

    在C++11中引入了auto類型說明符,用它就能讓編譯器替我們?nèi)シ治霰磉_式所屬的類型。當然,auto變量必須有初始值,這樣編譯器才能推斷其類型
    2016-03-03
  • C語言中對文件最基本的讀取和寫入函數(shù)

    C語言中對文件最基本的讀取和寫入函數(shù)

    這篇文章主要介紹了C語言中對文件最基本的讀取和寫入函數(shù),是C語言入門學習中的基礎(chǔ)知識,需要的朋友可以參考下
    2015-08-08
  • C語言數(shù)據(jù)結(jié)構(gòu)之圖書借閱系統(tǒng)

    C語言數(shù)據(jù)結(jié)構(gòu)之圖書借閱系統(tǒng)

    這篇文章主要為大家詳細介紹了C語言數(shù)據(jù)結(jié)構(gòu)之圖書借閱系統(tǒng),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • 使用C++創(chuàng)建多個IPC機制的上層接口

    使用C++創(chuàng)建多個IPC機制的上層接口

    設(shè)計一個上層的IPC接口,這個接口將在未來封裝底層的通信機制,這樣的設(shè)計要求接口足夠抽象,以便于底層實現(xiàn)的細節(jié)對上層用戶透明,本文給大家介紹了如何使用C++創(chuàng)建多個IPC機制的上層接口,文中通過代碼示例介紹的非常詳細,需要的朋友可以參考下
    2023-12-12
  • Qt實現(xiàn)自定義矩陣布局

    Qt實現(xiàn)自定義矩陣布局

    這篇文章主要為大家詳細介紹了Qt實現(xiàn)自定義矩陣布局,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-08-08
  • Qt圖形圖像開發(fā)曲線圖表模塊QChart庫縮放/平移詳細方法與實例

    Qt圖形圖像開發(fā)曲線圖表模塊QChart庫縮放/平移詳細方法與實例

    這篇文章主要介紹了Qt圖形圖像開發(fā)曲線圖表模塊QChart庫縮放/平移詳細方法與實例,需要的朋友可以參考下
    2020-03-03
  • C語言不定長數(shù)組及初始化方法

    C語言不定長數(shù)組及初始化方法

    今天小編就為大家分享一篇C語言不定長數(shù)組及初始化方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-07-07
  • C語言形參和實參傳值和傳址詳解刨析

    C語言形參和實參傳值和傳址詳解刨析

    形參出現(xiàn)在函數(shù)定義中,在整個函數(shù)體內(nèi)都可以使用, 離開該函數(shù)則不能使用。實參出現(xiàn)在主調(diào)函數(shù)中,進入被調(diào)函數(shù)后,實參變量也不能使用,形參和實參的功能是作數(shù)據(jù)傳送。發(fā)生函數(shù)調(diào)用時, 主調(diào)函數(shù)把實參的值傳送給被調(diào)函數(shù)的形參從而實現(xiàn)主調(diào)函數(shù)向被調(diào)函數(shù)的數(shù)據(jù)傳送
    2021-11-11
  • C++ 單例模式的詳解及實例

    C++ 單例模式的詳解及實例

    這篇文章主要介紹了C++ 單例模式的詳解及實例的相關(guān)資料,這里對單例中的懶漢模式和餓漢模式進行實現(xiàn)和比較,需要的朋友可以參考下
    2017-07-07
  • C語言求冪計算的高效解法

    C語言求冪計算的高效解法

    這篇文章主要介紹了C語言求冪計算的高效解法,分別演示了求冪運算與整數(shù)次方的解法,具有不錯的參考借鑒價值,需要的朋友可以參考下
    2014-09-09

最新評論