为啥我这个过不了啊?求大佬帮忙看看吧,我有写注释!

只能过86.67%,不知道问题出在哪了。

#include <bits/stdc++.h>
using namespace std;
#define rep(i,a,n) for(register int i=a;i<=n;++i)
struct p{
    int x,y,s;
    p(){}
    p(int x,int y,int s):x(x),y(y),s(s){}
};
// 数据数组。
string a[52];
// 标记数组。
bool b[52][52];
// 起点和终点。
p st,ed;
// 前4个是上下左右,后4个是斜着的方向。
int xx[8]={1,0,-1,0,1,1,-1,-1};
int yy[8]={0,1,0,-1,1,-1,1,-1};
int n,m;
void bfs(){
    queue<p>q;
    // 从起点开始找。
    q.push(st);
    // 标记起点走过了。
    b[st.x][st.y]=false;
    while(!q.empty()){
        p p1=q.front();
        q.pop();
        // 如果当前弹出的点是终点,就输出步数,并返回。
        if(p1.x==ed.x&&p1.y==ed.y){
            cout<<p1.s<<endl;
            return;
        }
        // 遍历上下左右四个方向
        rep(i,0,3){
            // tx,ty是下一个可能要走的点
            int tx=p1.x+xx[i],ty=p1.y+yy[i];
            // 如果tx,ty没有出界,并且a[tx][ty]是“.”可走,并且标记数组没标记过。(初始全true。)
            if(tx>0&&tx<=n&&ty>0&&ty<=m&&a[tx][ty]=='.'&&b[tx][ty]){
                // 就把这个点插入队列中,步数加1。
                q.push(p(tx,ty,p1.s+1));
                //标记这个点走过。
                b[tx][ty]=false;
            }
        }
    }
    // 如果出现无路可走的现象,代表不可能。
    puts("Impossible");
}
int main(){
    std::ios::sync_with_stdio(false);cin.tie(0);cout.tie(0);
    cin>>n>>m;
    register string x;
    a[0]=a[n+1]=" ";
    st.x=ed.x=st.y=ed.y=-1;
    // ---------------------------------------------
    // 这几步是把字符串数组打造成周围一圈空格。
    rep(i,0,n+1)rep(j,0,m+1)b[i][j]=true;
    rep(i,0,m){a[0]+=" ";a[n+1]=a[0];}
    rep(i,1,n){cin>>x;a[i]=" "+x+" ";}
    // ---------------------------------------------
    // 先遍历一遍整个数组,把所有的*的四周都变成#(如果变*可能会导致之后又遍历到。反正不是.就行了呗)
    rep(i,1,n)rep(j,1,m){
        if(a[i][j]=='*'){
            rep(k,0,7)a[i+xx[k]][j+yy[k]]='#';
        }
    }
    // 再次遍历整个数组,确定起点和终点位置。(他们俩初始都是-1,-1),这样可以判断起点和终点是否被#覆盖。找到了就给起点设置步数0,把终点改成“.”,方便之后判断是否可走。
    rep(i,1,n)rep(j,1,m){
        if(a[i][j]=='S'){
            st.x=i;st.y=j;st.s=0;
        }
        if(a[i][j]=='E'){
            ed.x=i;ed.y=j;
            a[i][j]='.';
        }
    }
    // 如果起点和终点中有一个是危险地带,就输出不可能。
    if(st.x==-1||ed.x==-1)puts("Impossible");
    else{
        // 否则就bfs查找最短步数。
        bfs();
    }
    return 0;
}
全部评论
结果最后还是我自己做出来了。原因是,我只考虑到了,如果把*周围8个位置变成*,继续往后遍历的话,可能会遇到这个被制造出来的*,所以我改成了井号。但是,我就忘了判断这个点之前是不是本身就是*。就导致,我是没有让*泛滥,却让*比应有的少了。
2 回复 分享
发布于 2020-06-15 09:07
巧了,我改了十几次也只能过86.67%,我人都傻了。
1 回复 分享
发布于 2020-07-29 10:51

相关推荐

06-13 17:33
门头沟学院 Java
顺序不记了,大致顺序是这样的,有的相同知识点写分开了1.基本数据类型2.基本数据类型和包装类型的区别3.==和equals区别4.ArrayList与LinkedList区别5.hashmap底层原理,put操作时会发生什么6.说出几种树型数据结构7.B树和B+树区别8.jvm加载类机制9.线程池核心参数10.创建线程池的几种方式11.callable与runnable区别12.线程池怎么回收线程13.redis三剑客14.布隆过滤器原理,不要背八股,说说真正使用时遇到了问题没有(我说没有,不知道该怎么回答了)15.堆的内存结构16.自己在写项目时有没有遇见过oom,如何处理,不要背八股,根据真实经验,我说不会17.redis死锁怎么办,watchdog机制如何发现是否锁过期18.如何避免redis红锁19.一个表性别与年龄如何加索引20.自己的项目的QPS怎么测的,有没有真正遇到大数量表21.说一说泛型22.springboot自动装配原理23.springmvc与springboot区别24.aop使用过嘛?动态代理与静态代理区别25.spring循环依赖怎么解决26.你说用过es,es如何分片,怎么存的数据,1000万条数据怎么写入库中27.你说用limit,那么在数据量大之后,如何优化28.rabbitmq如何批次发送,批量读取,答了延迟队列和线程池,都不对29.计网知不知道smtp协议,不知道写了对不对,完全听懵了30.springcloud知道嘛?只是了解反问1.做什么的?短信服务,信息量能到千万级2.对我的建议,基础不错,但是不要只背八股,多去实际开发中理解。面试官人不错,虽然没露脸,但是中间会引导我回答问题,不会的也只是说对我要求没那么高。面完问我在济宁生活有没有困难,最快什么时候到,让人事给我聊薪资了。下午人事打电话,问我27届的会不会跑路,还在想办法如何使我不跑路,不想扣我薪资等。之后我再联系吧,还挺想去的😭,我真不跑路哥😢附一张河科大幽默大专图,科大就是大专罢了
查看30道真题和解析
点赞 评论 收藏
分享
能干的三文鱼刷了100道题:公司可能有弄嵌入式需要会画pcb的需求,而且pcb能快速直观看出一个人某方面的实力。看看是否有面试资格。问你问题也能ai出来,pcb这东西能作假概率不高
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务