12.21 宽搜 二分 算法学习启动

宽搜

走迷宫
问题描述
给定一个 n×m 的二维整数数组,用来表示一个迷宫,数组中只包含 0 或 1,其中 0 表示可以走的路,1 表示不可通过的墙壁。

最初,有一个人位于左上角 (1,1) 处,已知该人每次可以向上、下、左、右任意一个方向移动一个位置。

请问,该人从左上角移动至右下角 (n,m) 处,至少需要移动多少次。

数据保证 (1,1) 处和 (n,m) 处的数字为 0,且一定至少存在一条通路。

输入格式
第一行包含两个整数 n 和 m。

接下来 n 行,每行包含 m 个整数(0 或 1),表示完整的二维数组迷宫。

输出格式
输出一个整数,表示从左上角移动至右下角的最少移动次数。

数据范围

1≤n,m≤100

样例

5 5
0 1 0 0 0
0 1 0 1 0
0 0 0 0 0
0 1 1 1 0
0 0 0 1 0
#include<bits/stdc++.h>
using namespace std;
const int N=1e4;
typedef pair<int,int> PII;
queue <PII>q;
int n,m,g[N][N],d[N][N],x,y;
int bfs()
{
	q.push({0,0});
	int dx[4]={1,0,-1,0},dy[4]={0,-1,0,1};
	memset(d,-1,sizeof d);
	d[0][0]=0;
	while(q.size()){
		auto t=q.front();
		q.pop();
		for(int i=0;i<4;i++){
		x=t.first+dx[i];
			y=t.second+dy[i];
			if(d[y][x]==-1&&g[y][x]==0&&x>=0&&x<m&&y>=0&&y<n)  //注意下 x y
			{
			d[y][x]=d[t.second][t.first]+1;	
			q.push({x,y});	
			}
		}
	}
	return d[n-1][m-1];
}
int main()
{
cin>>n>>m;
	for(int i=0;i<n;i++){
		for(int j=0;j<m;j++){
			cin>>g[i][j];
		}
	}
	cout<<bfs()<<endl;
	return 0;
}

二分 

 往左搜   mid  

               if(x<=a[mid])   r=mid        条件尽量向左

               l=mid+1

往右搜     mid=l+r+1>>1

                if(x>=a[mid])   l=mid        同理

                r=mid-1

实数二分

while(l-r>1e-5)

{

mid=(l+r)/2;

if() l=mid;

else r=mid;

}

例题明天再说吧

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值