基础算法bfs -剪枝问题

问题描述:一个迷宫有 NXM 格,有一些格子是地板,能走;有一些格子是障碍,不能走。给一个起点S和一个终点D。一只小狗从 S出发,每步走一块地板,在每块地员不能停留,而且走过的地板都不能再走。给定一个 T,问小狗能正好走 T步到达D吗?输入:有很多测试样例。每个测试中,第1行输入整数 N,M,T(1<N,M<7,0<T<50)。后面N 行中,每行输入M 个字符,有这些字符可以输入:'X':墙;S':起点;D:终点;",:地板。最后一行输入'000',表示输入结束。

输出:每个测试,如果狗能到达,输出YES,否则输出 NO。

cpp 复制代码
#include <iostream>
using namespace std;
char mat[8][8], visit[8][8];
int n, m, t;
int flag;
int a, b, c, d;
int dir[4][2] = { {1,0},{-1,0},{0,1},{0,-1} };
#define check(xx,yy)(xx>=0&&yy>=0&&xx<n&&yy<n)
void dfs(int time,int x,int y)
{
	if (flag)return;
	if (mat[x][y] =='D')
	{
		if(time==t)flag = 1;
		return;
	}

	int tem = t - time - (abs(c - x) + abs(d - y));
	if (tem < 0) return;
	for (int i = 0; i < 4; i++)
	{
		int xx = x + dir[i][0];
		int yy = y + dir[i][1];
		if (check(xx, yy) && mat[xx][yy] != 'X' && !visit[xx][yy])
		{
			visit[xx][yy] = 1;
			dfs(time + 1, xx, yy);
			visit[xx][yy] = 0;
		}
	}
	return;
}

void solve()
{
	cin >> n >> m >> t;	
	for (int i = 0; i < n; i++)
	{
		int ts = 0;
		for (int j = 0; j < m; j++)
		{
			cin >> mat[i][j];
			if (mat[i][j] == '0')ts++;
			if ('S'== mat[i][j])
			{
				a = i;
				b = j;
			}
			if ('D' == mat[i][j])
			{
				c = i;
				d = j;
			}
			
		}
		if (ts==3) break;
	}

	memset(visit, 0, sizeof(visit));
	int tem = t - abs(c - a) - abs(d - b);
	if (tem &1) { cout << "N0"; return; }
	flag = 0;
	visit[a][b] = 1;
	dfs(0, a, b);
	if (flag)
	{
		cout << "YES" << endl;
	}
	else
	{
		cout << "NO" << endl;
	}
}
signed main()
{
	ios::sync_with_stdio;
	cin.tie(0);
	cout.tie(0);
	int num = 1;

	while (num--)
	{
		solve();
	}
}
相关推荐
橘颂TA10 分钟前
【剑斩OFFER】算法的暴力美学——LeetCode 733 题:图像渲染
算法·leetcode·职场和发展
不穿格子的程序员13 分钟前
从零开始写算法——回溯篇2:电话号码的字母组合 + 组合总和
算法·深度优先·回溯
持梦远方1 小时前
算法剖析1:摩尔投票算法 ——寻找出现次数超过一半的数
c++·算法·摩尔投票算法
程序员-King.1 小时前
链表——算法总结与新手教学指南
数据结构·算法·链表
Ulyanov2 小时前
战场地形生成与多源数据集成
开发语言·python·算法·tkinter·pyside·pyvista·gui开发
FMRbpm2 小时前
树的练习6--------938.二叉搜索树的范围和
数据结构·c++·算法·leetcode·职场和发展·新手入门
wubba lubba dub dub7502 小时前
第三十三周 学习周报
学习·算法·机器学习
C+-C资深大佬2 小时前
C++数据类型
开发语言·c++·算法
多米Domi0112 小时前
0x3f 第35天 电脑硬盘坏了 +二叉树直径,将有序数组转换为二叉搜索树
java·数据结构·python·算法·leetcode·链表
想逃离铁厂的老铁2 小时前
Day45 >> 115、不同的子序列 + 583. 两个字符串的删除操作 + 72. 编辑距离
算法·leetcode