Tempter of the Bone(DFS)
沒有剪枝,超時
#include <iostream>
#include<cstdio>
#include<string.h>
using namespace std;
char map[10][10];
int flag,step;
int d[4][2]={0,1,1,0,0,-1,-1,0};
int ex,ey,sx,sy;
int n,m;
void dfs(int x,int y,int t)
{
if(flag==1)return ;
else if(t==0)
{
if(x==ex&&y==ey)
{
flag=1;return;
}
else return ;
}
else
for(int i=0;i<4;i++) //向四個方向深搜
{
int nx=x+d[i][0],ny=y+d[i][1];
if(nx>0&&nx<=n&&ny>0&&ny<=m&&(map[nx][ny]=='.'||map[nx][ny]=='D'))
{
map[nx][ny]='X'; //標記走過
dfs(nx,ny,t-1);
map[nx][ny]='.'; //回溯
}
}
}
int main(){
char str[10];
int t;
while(scanf("%d%d%d",&n,&m,&t)!=EOF)
{
if(n==0&&m==0)return 0;
for(int i=1;i<=n;i++)
{
scanf("%s",str);
for(int j=1;j<=m;j++)
{
map[i][j] = str[j-1];
if(map[i][j]=='S')
sx=i,sy=j;
else if(map[i][j]=='D')
ex = i,ey = j;
}
}
flag=0;
dfs(sx,sy,t);
if(flag==0)printf("NO\n");
else printf("YES\n");
}
return 0;
}
相關文章
- dynamic bone unity githubUnityGithub
- 基於react + redux的Bone框架ReactRedux框架
- DFS
- DFS樹
- dfs序
- dfs技巧
- 深搜dfs
- Prime Ring Problem (dfs)
- DAG bfs + dfs 126,
- 樹的DFS序
- DFS演算法原理演算法
- 圖的dfs_euler
- DFS序例題+感受
- DFS入門筆記筆記
- DFS(深度優先搜尋)
- 【題目整理】dfs入門
- 9*9的數獨(dfs)
- DFS剪枝最佳化策略
- 關於元素排列的DFS
- DFS實現拓撲排序排序
- P1219 八皇后(dfs)
- bzoj4500: 矩陣(dfs)矩陣
- HDU1427速算24點(dfs)
- HDU 1427-速算24點(DFS)
- 求樹的直徑(BFS/DFS)
- dfs的return時機問題
- 聊聊演算法——BFS和DFS演算法
- 數獨問題(DFS+回溯)
- HDU - 2553 N皇后問題(DFS)
- dfs時間複雜度分析時間複雜度
- L2-007 家庭房產【DFS】
- L2-020 功夫傳人【DFS】
- P1433 吃乳酪 (dfs+剪枝)
- hdu 6446 Tree and Permutation(dfs+思維)
- 藍橋杯-迷宮(BFS+DFS)
- P1101 單詞方陣【DFS】
- P1019 單詞接龍(dfs)
- L2_020功夫傳人(DFS)