大学生活题解

样例输入:

复制代码
3
.xA
...
Bx.

样例输出:

复制代码
6

思路分析:

这道题只需要在正常的广搜模板上多维护一个--- ---方向,如果当前改变方向,就坐标不变,方向变,步数加一;否则坐标变,方向不变,步数加一。

cpp 复制代码
#include<iostream>
#include<queue>
using namespace std;
int n,xy[4][2]={{1,0},{0,1},{-1,0},{0,-1}},ans=-1;
char a[110][110];
bool mk[110][110][4];
struct node{
	int x,y,step,cnt;//cnt记录方向
};
void bfs(int x,int y){//bfs模板
	queue<node>q;
	q.push((node){x,y,0,-1});//起点方向标记-1
	while(q.size()){
		node t=q.front();
		if(a[t.x][t.y]=='B'){//判断是否到终点
			ans=t.step;
			return;
		}
		q.pop();
		for(int i=0;i<4;i++){
			int xx=t.x+xy[i][0],yy=t.y+xy[i][1];//偏移量
			if(xx>=1&&xx<=n&&yy>=1&&yy<=n&&a[xx][yy]!='x'&&mk[xx][yy][i]==0){//判断越界等
				if(t.cnt==-1||t.cnt==i){//特判-1和方向不变
					mk[xx][yy][i]=1;
					q.push((node){xx,yy,t.step+1,i});
				}else{//方向改变
					q.push((node){t.x,t.y,t.step+1,i});
				}
			}
		}
	}
}
int main(){
	cin>>n;
	int x,y;
	for(int i=1;i<=n;i++){
		for(int j=1;j<=n;j++){
			cin>>a[i][j];
			if(a[i][j]=='A'){
				x=i,y=j;
			}
		}
	}
	bfs(x,y);
	cout<<ans;
	return 0;
}
相关推荐
2401_872418784 小时前
算法入门:数据结构-堆
数据结构·算法
王老师青少年编程4 小时前
信奥赛C++提高组csp-s之搜索进阶(搜索剪枝案例实践1)
c++·csp·高频考点·信奥赛·提高组·搜索剪枝·小木棍
xwz小王子5 小时前
手术机器人登上Science Robotics:2毫米纤细手臂,从3厘米切口完成腰椎神经减压
算法·机器人
黎阳之光6 小时前
视频孪生智护供水生命线:黎阳之光赋能医疗与园区水务高质量升级
运维·物联网·算法·安全·数字孪生
Black蜡笔小新7 小时前
自动化AI算法训练服务器DLTM制造业AI质检工作站助力制造业实现AI智检
人工智能·算法·自动化
嵌入式小能手7 小时前
飞凌嵌入式ElfBoard-进程间的通信之命名管道
linux·服务器·算法
啦哈拉哈7 小时前
Leetcode题解记录-hot100(81-100)
算法·leetcode·职场和发展
csdn_aspnet8 小时前
Java 霍尔分区算法(Hoare‘s Partition Algorithm)
java·开发语言·算法
王老师青少年编程8 小时前
信奥赛C++提高组csp-s之搜索进阶(搜索剪枝核心思想 )
c++·dfs·csp·信奥赛·搜索剪枝·搜索优化
一拳一个呆瓜8 小时前
【STL】使用 C++ 标准库标头
c++·stl