当前位置: 首页 > article >正文

迷宫【BFS+结构体\pair】

题目

代码-结构体

#include<iostream>
#include<algorithm>
#include<queue>
#include<cstring>
using namespace std;

int n,m;
int mp[110][110];
int dx[]={0,0,1,-1};
int dy[]={1,-1,0,0};
int d[110][110];
struct node{
    int x;
    int y;
};

void bfs(){
	queue<node> q;
	memset(d,-1,sizeof d);	
	q.push({0,0});
	d[0][0]=0;
	while(q.size()!=0){
		node tmp = q.front();
		q.pop();
		
		for(int i=0;i<4;i++){
			int nx=tmp.x + dx[i];
			int ny=tmp.y + dy[i];
			
			if(nx>=0 && nx<n && ny>=0 && ny<m && mp[nx][ny]==0 &&d[nx][ny] == -1){
				d[nx][ny] = d[tmp.x][tmp.y] + 1;
				q.push({nx,ny});
			}			
		}		
	}
	
}
int main()
{
	cin>>n>>m;
	for(int i=0;i<n;i++){
		for(int j=0;j<m;j++){
			cin>>mp[i][j];
		}
	}
	bfs();
	cout<<d[n-1][m-1]<<endl;
 } 

代码-pair

#include<iostream>
#include<algorithm>
#include<queue>
#include<cstring>
using namespace std;

int n,m;
int mp[110][110];
int dx[]={0,0,1,-1};
int dy[]={1,-1,0,0};
int d[110][110];
typedef pair<int,int> PII;

void bfs(){
	queue<PII> q;
	memset(d,-1,sizeof d);	
	q.push({0,0});
	d[0][0]=0;
	while(q.size()!=0){
		PII tmp = q.front();
		q.pop();
		
		for(int i=0;i<4;i++){
			int nx=tmp.first + dx[i];
			int ny=tmp.second + dy[i];
			
			if(nx>=0 && nx<n && ny>=0 && ny<m && mp[nx][ny]==0 &&d[nx][ny] == -1){
				d[nx][ny] = d[tmp.first][tmp.second] + 1;
				q.push({nx,ny});
			}			
		}		
	}
	
}
int main()
{
	cin>>n>>m;
	for(int i=0;i<n;i++){
		for(int j=0;j<m;j++){
			cin>>mp[i][j];
		}
	}
	bfs();
	cout<<d[n-1][m-1]<<endl;
 } 


http://www.kler.cn/a/576999.html

相关文章:

  • 力扣每日一题——2597. 美丽子集的数目
  • HarmonyOS Next 属性动画和转场动画
  • 【算法 C/C++】一维前缀和
  • 面试过了,总结测试工程师面试题(含答案)
  • Github 2025-03-08Rust开源项目日报Top10
  • 【JAVA架构师成长之路】【Redis】第15集:Redis大Key问题分析与解决方案
  • FPGA学习篇——Verilog学习5(reg,wire区分及模块例化)
  • 大数据表高效导入导出解决方案,mysql数据库LOAD DATA命令和INTO OUTFILE命令详解
  • AORO P9000 PRO三防平板携手RTK高精度定位,电力巡检效率倍增
  • ShardingSphere 和 Spring 的动态数据源切换机制的对比以及原理
  • 解决电脑问题(5)——鼠标问题
  • 后门攻击仓库 backdoor attack
  • 计算机毕业设计SpringBoot+Vue.js制造装备物联及生产管理ERP系统(源码+文档+PPT+讲解)
  • 基于Asp.net的驾校管理系统
  • Windows 远程桌面多端口访问,局域网虚拟IP映射多个Windows 主机解决方案
  • 使用 Docker 部署 Nginx,配置后端 API 轮询与多个子域名前端应用
  • RHCE9.0版本笔记4:聚焦网络安全基础技术
  • 头歌作业-mysql数据库系统(全部)
  • 【Json RPC框架】框架介绍与环境搭建(Ubuntu 22.04)
  • 解决电脑问题(3)——显示器问题