dfs(续做)

1.混境之地5
cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const int dx[4]= {0,1,0,-1};
const int dy[4]= {1,0,-1,0};
int n,m,k,a,b,c,d,sign=0;
int h[1010][1010],visit[1010][1010];
void dfs(int x,int y,bool used)
{
	if(x==c&&y==d)
	{
		sign++;
		return;
	}
	if(x<1||y<1||x>n||y>m||visit[x][y])
	{
		return;
	}
	for(int i=0; i<4; i++)
	{
		int nx=x+dx[i];
		int ny=y+dy[i];
		if(h[nx][ny]<=h[x][y])
		{
			dfs(nx,ny,used);
		}
		else if(!used&&h[nx][ny]<=h[x][y]+k)
		{
			dfs(nx,ny,true);
		}
	}
}
int main()
{
	memset(visit,0,sizeof(visit));
	cin>>n>>m>>k;
	cin>>a>>b>>c>>d;
	for(int i=1; i<=n; i++)
	{
		for(int j=1; j<=m; j++)
		{
			cin>>h[i][j];
		}
	}
	dfs(a,b,false);
	if(sign)
	{
		cout<<"Yes"<<endl;
	}
	else
	{
		cout<<"No"<<endl;
	}
	return 0;
}
2.小怂爱水洼
cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const int dx[4]= {0,1,0,-1};
const int dy[4]= {1,0,-1,0};
ll n,m,sum=0,current_sum=0;
int a[110][110],visit[110][110];
void dfs(int x,int y)
{
	if(x<1||y<1||x>n||y>m)
	{
		return;
	}
	if(visit[x][y]==1||a[x][y]==0)
	{
		return;
	}
	current_sum+=a[x][y];
	visit[x][y]=1; 
	for(int i=0; i<4; i++)
	{
		int nx=dx[i]+x;
		int ny=dy[i]+y;
		dfs(nx,ny);	
	}
}
int main()
{
	cin>>n>>m;
	for(int i=1; i<=n; i++)//索引从1开始,保证nx,ny不会访问到非法地址 
	{
		for(int j=1; j<=m; j++)
		{
			cin>>a[i][j];
		}
	}
	memset(visit,0,sizeof(visit));
	for(int i=1; i<=n; i++)
	{
		for(int j=1; j<=m; j++)
		{
			current_sum=0;
			if(a[i][j]>0&&visit[i][j]!=1)
			{
				dfs(i,j);
				sum=max(sum,current_sum);
			}
		}
	}
	cout<<sum<<endl;
	return 0;
}
相关推荐
B325帅猫-量子前沿技术研究所21 小时前
PSD和FFT的关系
人工智能·算法
闻缺陷则喜何志丹21 小时前
【排序】P6149 [USACO20FEB] Triangles S|普及+
c++·算法·排序·洛谷
avocado_green21 小时前
【LeetCode】90. 子集 II
算法·leetcode
tankeven21 小时前
HJ178 【模板】双指针
c++·算法
君义_noip21 小时前
信息学奥赛一本通 4131:【GESP2506六级】学习小组 | 洛谷 P13015 [GESP202506 六级] 学习小组
算法·动态规划·gesp·信息学奥赛
6Hzlia1 天前
【Hot 100 刷题计划】 LeetCode 72. 编辑距离 | C++ 经典 DP 增删改状态转移
c++·算法·leetcode
穿条秋裤到处跑1 天前
每日一道leetcode(2026.04.16):距离最小相等元素查询
算法·leetcode·职场和发展
XY_墨莲伊1 天前
【实战项目】基于B/S结构Flask+Folium技术的出租车轨迹可视化分析系统(文末含完整源代码)
开发语言·后端·python·算法·机器学习·flask
小雅痞1 天前
[Java][Leetcode simple] 1. 两数之和
java·算法·leetcode
somi71 天前
ARM-驱动-09-LCD FrameBuffer
arm开发·驱动开发·算法·自用