当前位置: 首页 > news >正文

东营教育信息网官网福州360手机端seo

东营教育信息网官网,福州360手机端seo,龙湾建设智慧网站,淘宝客可以做返利网站吗引言 之前刚学DFS的时候并不完全理解为什么递归可以一直往下做,后来直到了递归的本质是栈,就想着能不能手写栈来代替递归呢。当时刚学,自己觉得水平不够就搁置了这个想法,今天上数据结构老师正好讲了栈的应用,其中就有…

引言

之前刚学DFS的时候并不完全理解为什么递归可以一直往下做,后来直到了递归的本质是栈,就想着能不能手写栈来代替递归呢。当时刚学,自己觉得水平不够就搁置了这个想法,今天上数据结构老师正好讲了栈的应用,其中就有一个走迷宫问题,于是写下这篇文章,希望能帮助大家更好的理解DFS。

B3625 迷宫寻路 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn)

DFS

#include<bits/stdc++.h>
const int N=110;
char g[N][N];
bool st[N][N];
int n,m;
int dx[]={0,1,0,-1};
int dy[]={1,0,-1,0};
int flag=0;
void dfs(int x,int y)
{if(flag) return;if(x==n&&y==m){flag=1;return ;}for(int i=0;i<4;i++){int a=x+dx[i];int b=y+dy[i];if(a<1||b<1||a>n||b>m) continue;if(g[a][b]=='#') continue;if(st[a][b]) continue;st[a][b]=true;dfs(a,b);if(flag) return;st[a][b]=false;}return ;
}
signed main()
{std::cin>>n>>m;for(int i=1;i<=n;i++){for(int j=1;j<=m;j++){std::cin>>g[i][j];}}st[1][1]=true;dfs(1,1);if(!flag) std::cout<<"No"<<'\n';else std::cout<<"Yes"<<'\n';return 0;
}

因为这题数据是100,所以DFS是过不了哒。正解应该是BFS。 

 栈的写法可以直接ac,效率可见一斑。

#include<bits/stdc++.h>
const int N=110;
typedef std::pair<int,int> PII;
char g[N][N];
bool st[N][N];
int n,m;
int dx[]={0,1,0,-1};
int dy[]={1,0,-1,0};
int flag=0;void dfs(int x,int y)
{std::stack<PII> stk;st[x][y]=true;stk.push({x,y});while(!stk.empty()){auto t=stk.top();int a=t.first;int b=t.second;if(a==n&&b==m){flag=1;return ;}int ok=0;for(int i=0;i<4;i++){int na=a+dx[i],nb=b+dy[i];if(g[na][nb]=='#') continue;if(st[na][nb]) continue;if(a<1||b<1||a>n||b>m) continue;//这个点可以走ok=1;st[na][nb]=true; stk.push({na,nb});}if(!ok){//不回溯是因为到这一步说明这个点是死胡同 //st[stk.top().first][stk.top().second]=0;stk.pop();}}return ;
}
signed main()
{std::cin>>n>>m;for(int i=1;i<=n;i++){for(int j=1;j<=m;j++){std::cin>>g[i][j];}}dfs(1,1);if(flag) std::cout<<"Yes"<<'\n';else std::cout<<"No"<<'\n';return 0;
}

BFS

宽度优先搜索

#include<bits/stdc++.h>
typedef std::pair<int,int> PII;
const int N=110;
int n,m;
char g[N][N];
int dist[N][N];
PII q[N*N];
int hh=0,tt=-1;
int dx[]={0,1,0,-1};
int dy[]={1,0,-1,0};void bfs(int x,int y)
{memset(dist,-1,sizeof dist);dist[x][y]=0;q[++tt]={x,y};while(hh<=tt){PII t=q[hh++];for(int i=0;i<4;i++){int a=t.first+dx[i];int b=t.second+dy[i];if(dist[a][b]!=-1) continue;if(g[a][b]=='#') continue;if(a<1||b<1||a>n||b>m) continue;q[++tt]={a,b};dist[a][b]=dist[x][y]+1;if(a==n&&b==m) {std::cout<<"Yes";return ;}}}std::cout<<"No";return ;
}
signed main()
{std::cin>>n>>m;for(int i=1;i<=n;i++){for(int j=1;j<=m;j++){std::cin>>g[i][j];} }bfs(1,1);return 0;
}

http://www.ds6.com.cn/news/45506.html

相关文章:

  • 品牌网站制作公司无锡百度推广代理商
  • 网区建站友情链接2598
  • 如何做网站建设团队建设网络营销品牌公司
  • b站推广链接搜索引擎优化seo网站
  • 百姓网网站源码西安百度代运营
  • 在山东省建设监理协会网站百度关键词规划师工具
  • 网站推广平台什么是百度指数
  • 给公司建网站国内最好的seo培训
  • c 做网站怎么插入id怎么建网页
  • wordpress 当前栏目seo网站推广计划
  • 廊坊网站优化百度公司在哪
  • 网站建设最新技术百度一下你知道
  • 网站后台编辑教程广告投放推广平台
  • 预约网站如何自己做百度seo公司电话
  • 衡水网站建设电话刷移动关键词优化
  • 上海网站关键词疫情防控最新政策
  • 做去态网站要学什么语言seo全网推广
  • 阜宁专业做网站黑帽seo排名
  • 网站营销的优势制作公司网站的步骤
  • 哪个独立网站做的比较好西部数码域名注册官网
  • 公司网站建设项目的成本计划怎么建网站免费的
  • 临安做网站湖南网站推广
  • 如何通过域名直接访问wordpressseo优化公司
  • 网站备案大概多久太原网站建设方案咨询
  • 如何给网站做外链百度认证营销推广师
  • 糗百网站源码seowhy
  • 网站空间月流量优化培训内容
  • 互联网科技公司做网站哪家好路由优化大师
  • 临沂网站服务器价格搜索引擎搜索
  • 网站建设方案书是什么谷歌官方网站登录入口