AcWing 175. 电路维修 BFS+双端队列

该博客主要探讨了一种使用宽度优先搜索(BFS)算法来解决网格中寻找最短路径的问题。代码示例展示了如何初始化并遍历网格,更新最短路径,并处理边界条件。博客还提供了参考链接和视频教程以帮助读者更好地理解算法实现。
摘要由CSDN通过智能技术生成

注意边界:
在这里插入图片描述

/*
参考题解:
https://www.acwing.com/solution/content/26973/ 
https://www.acwing.com/solution/content/21775/
观看视频:
https://www.acwing.com/video/132/ 
*/ 

#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
typedef unsigned long long ull;
typedef pair<int,int> pii;
#define pb push_back
#define fi first
#define se second
#define mem(a,x) memset(a,x,sizeof(a));
#define db double 
#define fir(i,a,n) for(int i=a;i<=n;i++)
#define debug(x) cout<<#x<<" "<<x<<endl;
const int inf=0x3f3f3f3f;
const int MOD=1e9+7;
//要注意边界范围======================
const int N=510;
int n,m;
char g[N][N];
int ans[N][N];
deque<pii>dq;
int dx[4]={-1,-1,1,1};
int dy[4]={-1,1,-1,1};//格点的四个方向 
int ix[4]={-1,-1,0,0};
int iy[4]={-1,0,-1,0}; 
string idxy="\\//\\";
void bfs()
{
	dq.clear();
	mem(ans,0x3f);
	dq.push_back({0,0});
	ans[0][0]=0;
	while(dq.size())
	{
		auto t=dq.front();
		dq.pop_front();
		
		for(int i=0;i<4;i++)
		{
			int x=t.fi+dx[i];
			int y=t.se+dy[i];
			
			if(x>=0&&x<=n&&y>=0&&y<=m)
			{
				int w=0;//先假设权值为0
				int xx=t.fi+ix[i];
				int yy=t.se+iy[i];
				if(g[xx][yy]!=idxy[i]) w=1;
				if(ans[x][y]>ans[t.fi][t.se]+w)
				{
					ans[x][y]=ans[t.fi][t.se]+w;
					if(w) dq.push_back({x,y});
					else dq.push_front({x,y});
				}
			}
		}
	}
}
int main()
{
	int t;cin>>t;
	while(t--)
	{
		cin>>n>>m;
		for(int i=0;i<n;i++) cin>>g[i];
		bfs();
		if(ans[n][m]==0x3f3f3f3f) cout<<"NO SOLUTION";
		else cout<<ans[n][m];
		cout<<endl;
	}
	return 0; 
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

karshey

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值