蓝桥杯专题 bfs习题详解

1.离开中山路

cpp 复制代码
#include<iostream>
#include<cstring>
#include<queue>
#include<algorithm>
#include<string>
using namespace std;
int x1,x2,y1,y2;
int n,n1,m1;
const int N=1010;


typedef pair<int,int> PII;
queue<PII> q;

int dist[N][N];
char g[N][N];

int dx[]={-1,0,1,0};
int dy[]={0,1,0,-1};

int bfs(int x1,int y1)
{
	memset(dist,-1,sizeof dist);
	q.push({x1,y1});//注意格式 
	
	dist[x1][y1]=0;
	while(!q.empty())
	{
		PII t=q.front();
		q.pop();
		for(int i=0;i<4;i++)
		{
			n1=dx[i]+t.first;
			m1=dy[i]+t.second;
			if(n1<1||n1>n||m1<1||m1>n) continue;
			if(g[n1][m1]=='1') continue;
			if(dist[n1][m1]>0) continue;
			
			q.push({n1,m1});
			dist[n1][m1]=dist[t.first][t.second]+1;// ***
			if(n1==x2&&m1==y2)
			{
				return dist[x2][y2];
			}
		}
	}
	return dist[x2][y2];
}


int main()
{
	scanf("%d",&n);
	for(int i=1;i<=n;i++)
	{
		for(int j=1;j<=n;j++)
		{
			cin>>g[i][j];
			//scanf("%c",&g[i][j]);
		}
	}
	scanf("%d %d %d %d",&x1,&y1,&x2,&y2);
	int res=bfs(x1,y1);
	cout<<res;
	return 0;
 } 

2.马的遍历

cpp 复制代码
//马的遍历
#include<iostream>
#include<algorithm>
#include<cstring>
using namespace std;
/*如何用数组模拟队列:省时间 
对头hh,队尾tt 
 实现队列的插入操作:q[tt++]=x;x是要插入的数字
 实现队列的弹出操作:hh++;
 如何给队列判空:当hh++<=tt 
 int hh=0,tt=0;*/
 typedef pair<int,int> PII;
 
 const int N=410;
 
 int n,m;
 int dist[N][N];
 PII q[N*N];
 
 int dx[]={2,2,1,1,-1,-1,-2,-2};
 int dy[]={-1,1,2,-2,2,-2,1,-1};
 
 void bfs(int x1,int y1)
 {
 	memset(dist,-1,sizeof dist);
 	q[0]={x1,y1};
 	dist[x1][y1]=0;
 	int hh=0,tt=0;
 	
 	while(hh<=tt)
 	{
 		PII t=q[hh++];//t=q.front,why++?
 		//hh++;//pop
 		//t=q[hh++];
 		for(int i=0;i<8;i++)
 		{
 			int a=t.first+dx[i];
 			int b=t.second+dy[i];
 			
 			if(a<1||a>n||b<1||b>m) continue;
 			if(dist[a][b]>=0) continue;
 			
 			dist[a][b]=dist[t.first][t.second]+1;
 			q[++tt]={a,b};//
 			
		 }
	 }
 }
 
int main()
{
	int x1,y1;
	scanf("%d %d %d %d",&n,&m,&x1,&y1);
	bfs(x1,y1);
	for(int i=1;i<=n;i++)
	{
		for(int j=1;j<=m;j++)
		{
		printf("%-5d",dist[i][j]);//%-5d左补空格,右对齐 
	
		}
		cout<<endl;	
	}
	return 0;
}
相关推荐
·云扬·1 小时前
【Leetcode hot 100】101.对称二叉树
算法·leetcode·职场和发展
Greedy Alg6 小时前
LeetCode 142. 环形链表 II
算法
睡不醒的kun6 小时前
leetcode算法刷题的第三十二天
数据结构·c++·算法·leetcode·职场和发展·贪心算法·动态规划
先做个垃圾出来………7 小时前
残差连接的概念与作用
人工智能·算法·机器学习·语言模型·自然语言处理
SuperCandyXu8 小时前
P3205 [HNOI2010] 合唱队-普及+/提高
c++·算法·洛谷
_OP_CHEN9 小时前
数据结构(C语言篇):(十二)实现顺序结构二叉树——堆
c语言·数据结构·算法·二叉树·学习笔记··顺序结构二叉树
Yingjun Mo9 小时前
1. 统计推断-基于神经网络与Langevin扩散的自适应潜变量建模与优化
人工智能·神经网络·算法·机器学习·概率论
地平线开发者10 小时前
征程 6 | 灰度图部署链路介绍
算法·自动驾驶
地平线开发者10 小时前
手撕大模型|KVCache 原理及代码解析
算法·自动驾驶
共享家952711 小时前
经典动态规划题解
算法·leetcode·动态规划