P1535 [USACO08MAR] Cow Travelling S(dfs+剪枝 or 记忆化搜索)

1:本题暴力做法简单,重点在于我们如何剪枝:

:《曼哈顿距离》我们每走一个点就判断,当前点到终点的最短步数是不是小于当前剩余的步数,

如果大于就肯定不符合直接return,或者当步数为0时,当还没到达终点,那也return不符合

2:另外当我们到达终点时,步数要刚好用才行.

3ACcode:

#include<bits/stdc++.h>
using namespace std;
#define int long long
const int N=1e2+10;
int n,m,t,sx,sy,ex,ey,cnt;
int idx[]={0,0,1,-1},idy[]={1,-1,0,0};
char mp[N][N];
bool vis[N][N];
void dfs(int x,int y,int left_t){
	
	if(x==ex&&y==ey&&left_t==0){//结束 
		cnt++;
        return;
	}
	//剪枝 
	if((abs(ex-x)+abs(ey-y))>left_t) return;//曼哈顿离终点最短距离 
	 if(left_t==0) return;
	 //通过当前标记点不能到达终点,后面再通过其他路径经过这点也肯定到不了终点
	 //所以不用回溯 
	for(int i=0;i<4;i++){
		int xx=x+idx[i];
		int yy=y+idy[i];
		if(xx<1||xx>n||yy<1||yy>m||mp[xx][yy]=='*')
		continue;
		dfs(xx,yy,left_t-1);
	}
}
void solve() {
  cin>>n>>m>>t;
  for(int i=1;i<=n;i++)
  for(int j=1;j<=m;j++)
  cin>>mp[i][j];
  cin>>sx>>sy>>ex>>ey;
  dfs(sx,sy,t);
  cout<<cnt<<"\n";
}
signed main() {
	ios::sync_with_stdio(false),cin.tie(0),cout.tie(0);
	solve();
	return 0;
}

记忆化搜索

over~

相关推荐
ZZZ_O^O16 分钟前
二分查找算法——寻找旋转排序数组中的最小值&点名
数据结构·c++·学习·算法·二叉树
CV-King40 分钟前
opencv实战项目(三十):使用傅里叶变换进行图像边缘检测
人工智能·opencv·算法·计算机视觉
代码雕刻家1 小时前
数据结构-3.9.栈在递归中的应用
c语言·数据结构·算法
雨中rain1 小时前
算法 | 位运算(哈希思想)
算法
Kalika0-03 小时前
猴子吃桃-C语言
c语言·开发语言·数据结构·算法
sp_fyf_20243 小时前
计算机前沿技术-人工智能算法-大语言模型-最新研究进展-2024-10-02
人工智能·神经网络·算法·计算机视觉·语言模型·自然语言处理·数据挖掘
我是哈哈hh5 小时前
专题十_穷举vs暴搜vs深搜vs回溯vs剪枝_二叉树的深度优先搜索_算法专题详细总结
服务器·数据结构·c++·算法·机器学习·深度优先·剪枝
Tisfy5 小时前
LeetCode 2187.完成旅途的最少时间:二分查找
算法·leetcode·二分查找·题解·二分
Mephisto.java5 小时前
【力扣 | SQL题 | 每日四题】力扣2082, 2084, 2072, 2112, 180
sql·算法·leetcode
robin_suli5 小时前
滑动窗口->dd爱框框
算法