以前的一道题目,现在拿到总觉得是DFS,然后T掉就没什么想法了,很狗的看了以前的写法(以前还是看题解的AC的),是BFS,每次都要转弯,但是之前你的达到一种他走到了死路,所以才是不得不转弯,写法也是非常棒,预处理的转弯数是-1就可以达到一开始转弯的+1抵消。

DFS写法:

中间判断两个条件,如果是起点,不是起点,然后剪枝的话,就是有flag直接return,还有那个点不行也return,主要是转弯数不行或者点不是都要return。

#include<iostream>
#include<cstdio>
#include<math.h>
#include<queue>
#include<map>
#include<stdlib.h>
#include<string>
#include<string.h>
#include<algorithm>
using namespace std;
typedef long long LL;
#define PI acos(-1.0) const int N=1e2+10; bool vis[N][N];
int n,m;
char ma[N][N];
int sx,sy;
int ex,ey;
int k; int dx[4]={1,-1,0,0};
int dy[4]={0,0,-1,1};
int flag; struct asd{
int x,y;
int num;
}; bool JUDGE(int x,int y)
{
if(x<=0||y<=0||x>n||y>m||ma[x][y]=='*')
return 0;
return 1;
}
queue<asd>q; void BFS()
{
while(!q.empty())
q.pop();
memset(vis,0,sizeof(vis)); if(sx==ex&&sy==ey){
flag=1;
return;
} asd now,ne;
now.x=sx;now.y=sy;
now.num=-1;
vis[now.x][now.y]=1;
q.push(now); while(!q.empty())
{
now=q.front();
q.pop();
for(int i=0;i<4;i++)
{
ne.x=dx[i]+now.x;
ne.y=dy[i]+now.y; //因为之前肯定是不能再走下去了,所以必须转弯。
while(JUDGE(ne.x,ne.y)){ //然后一直在这个方向走走,走到不能走为止。
if(!vis[ne.x][ne.y]){
ne.num=now.num+1;
vis[ne.x][ne.y]=1;
if(ne.x==ex&&ne.y==ey&&ne.num<=k){
flag=1;
return;
}
q.push(ne);
}
ne.x+=dx[i];
ne.y+=dy[i];
}
}
}
} int main()
{
int t;
cin>>t;
while(t--)
{
scanf("%d%d",&n,&m);
for(int i=1;i<=n;i++)
scanf("%s",ma[i]+1);
scanf("%d",&k);
scanf("%d%d%d%d",&sy,&sx,&ey,&ex);
flag=0;
BFS();
if(flag)
printf("yes\n");
else
printf("no\n");
}
return 0;
}

DFS写法

#include <bits/stdc++.h>
using namespace std;
typedef long long LL;
typedef unsigned long long ULL;
typedef pair<int, int> PI;
typedef pair< PI, int> PII;
const double eps=1e-5;
const double pi=acos(-1.0);
const int mod=1e9+7;
const int INF=0x3f3f3f3f;
const int N=110; char ma[N][N];
int vis[N][N];
int n,m,num;
int sx,sy,tx,ty,flag;
int dx[4]={0,0,-1,1};
int dy[4]={1,-1,0,0}; void dfs(int x,int y,int d)
{
int i;
if(vis[x][y]>num)
return;
if(vis[x][y]==num&&(x!=tx&&y!=ty))
return;
if(flag)
return; if(x==tx&&y==ty){
if(vis[x][y]<=num)
flag=1;
return;
}
for(i=0;i<4;i++){
int xx=dx[i]+x;
int yy=dy[i]+y;
if(xx<0||yy<0||xx>=n||yy>=m||ma[xx][yy]=='*'||vis[xx][yy]<vis[x][y])
continue;
if(d!=-1&&i!=d&&vis[xx][yy]<vis[x][y]+1)
continue;
vis[xx][yy]=vis[x][y];
if(d!=-1&&i!=d){
vis[xx][yy]++;
}
dfs(xx,yy,i);
}
}
int main()
{
int T,i;
cin>>T;
while(T--){
scanf("%d%d",&n,&m);
for(i=0;i<n;i++){
scanf("%s",ma[i]);
}
scanf("%d%d%d%d%d",&num,&sy,&sx,&ty,&tx);
sy--;sx--;tx--;ty--;
flag=0;
memset(vis,1,sizeof(vis));
vis[sx][sy]=0;
dfs(sx,sy,-1);
if(flag) printf("yes\n");
else printf("no\n");
}
return 0;
}

最新文章

  1. Javassist 通用工具之 CodeInjector
  2. 【HDU 5835】Danganronpa(分配礼物)
  3. [转]ionic项目之上传下载数据
  4. 刀哥多线程同步任务作用gcd-07-sync_task
  5. LoadRunner中的参数与变量
  6. 在ASP中调用DLL的方法
  7. Java经典23种设计模式之结构型模式(一)
  8. winform制作自定义控件(入门)
  9. Ubuntu14.04配置Apache支持多个站点
  10. python抓取历年特码开奖记录
  11. 【mysql】mysql基本操作
  12. C语言程序设计第三次作业——选择结构(1)
  13. pycharm跨目录调用文件
  14. 报文ISO8583协议
  15. 【开源】OSharpNS,轻量级.net core快速开发框架发布
  16. OpenStack-Storage(6)
  17. 让Entity Framework不再私闯sys.databases
  18. 一、Selenium 工作原理
  19. bat中errorlevel与%errorlevel%的区别
  20. thinkphp 3.2.1 URL 大小写问题 下面有具体说明

热门文章

  1. takeLatest 如何接受 this.props.dispatch 传递的参数
  2. vue2.0 常用的 UI 库
  3. 如何给老婆解释什么是RESTful
  4. [PHP]PDO调用存储过程
  5. CarbonData
  6. gitlab merge过程
  7. node封装mysql模块
  8. Mybatis中的大于等于和小于等于
  9. java 读写Oracle Blob字段
  10. windows下安装composer流程