AtCoder Beginner Contest 170 F. Pond Skater

41 篇文章 0 订阅

AtCoder Beginner Contest 170 F. Pond Skater

题目链接
在这里插入图片描述
第一次碰到会写的 F,真的哭辽/(ㄒoㄒ)/~~,BFS+剪枝
题目有几个坑点:
1.初始化,我们直接用变量建二维数组不一定就是0,要初始化一下
2.剪枝是一门艺术,怎么剪效果最好,这题的关键就是步数判断,假如 a a a 能 BFS 到 b b b,如果此时 b b b 的步数已经小于等于 a a a 了,那么很明显就没有走下去的必要了
AC代码如下:

#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
struct node{
    int x,y;
};
int h,w,sx,sy,ex,ey,k;
int mo[4][2]={1,0,-1,0,0,1,0,-1};
main(){
    cin>>h>>w>>k;
    cin>>sx>>sy>>ex>>ey;
    char g[h][w];
    int step[h][w],vis[h][w];
    memset(vis,0,sizeof(vis));
    memset(step,0,sizeof(step));
    for(int i=0;i<h;i++){
        for(int j=0;j<w;j++)
            cin>>g[i][j];
    }
    sx--,sy--,ex--,ey--;
    queue<node>q;
    node a,b;
    a.x=sx;a.y=sy;step[a.x][a.y]=0;vis[a.x][a.y]=1;
    q.push(a);
    int ans=1e9;
    while(!q.empty()){
        a=q.front();
        q.pop();
        if(a.x==ex && a.y==ey) ans=min(ans,step[a.x][a.y]);
        for(int i=0;i<4;i++){
            for(int j=1;j<=k;j++){
                b.x=a.x+mo[i][0]*j;
                b.y=a.y+mo[i][1]*j;
                if(b.x<0||b.x>=h||b.y<0||b.y>=w||(step[b.x][b.y]&&step[b.x][b.y]<=step[a.x][a.y])) break;
                else{
                    if(g[b.x][b.y]=='.'&&vis[b.x][b.y]==0){
                        vis[b.x][b.y]=1;
                        step[b.x][b.y]=step[a.x][a.y]+1;
                        q.push(b);
                    }
                    else if(g[b.x][b.y]=='@') break;
                }
            }
        }
    }
    ans==1e9?cout<<-1:cout<<ans;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

旺 崽

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

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

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

打赏作者

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

抵扣说明:

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

余额充值