码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • [蓝桥杯2015决赛]穿越雷区 (BFS)


    题目描述

    X星的坦克战车很奇怪,它必须交替地穿越正能量辐射区和负能量辐射区才能保持正常运转,否则将报废。
    某坦克需要从A区到B区去(A,B区本身是安全区,没有正能量或负能量特征),怎样走才能路径最短?
    已知的地图是一个方阵,上面用字母标出了A,B区,其它区都标了正号或负号分别表示正负能量辐射区。
    例如:

    A + - + -
    - + - - +
    - + + + -
    + - + - +
    B + - + -

    坦克车只能水平或垂直方向上移动到相邻的区。

    思路

    首先想到的是dfs,每次更新最小值,于是,超时,,恍然大悟,改用bfs。

    最短路问题通常都可以考虑使用BFS宽搜。

    代码

    1. #include
    2. using namespace std;
    3. int n;
    4. char mp[102][102];
    5. int ans;
    6. int dx[4]={0,0,1,-1},dy[4]={1,-1,0,0};
    7. bool st[102][102];
    8. int flag=0;
    9. struct node{
    10. int x,y,step;
    11. };
    12. void bfs(int x,int y){
    13. queueq;
    14. q.push({x,y,0});
    15. st[x][y]=1;
    16. while(q.size()){
    17. node t=q.front();q.pop();
    18. x=t.x,y=t.y;
    19. int step=t.step;
    20. if(mp[x][y]=='B'){
    21. flag=1;
    22. ans=step;
    23. return ;
    24. }
    25. for(int i=0;i<4;i++){
    26. int xx=x+dx[i];
    27. int yy=y+dy[i];
    28. if(xx>=0&&xx=0&&yy
    29. q.push({xx,yy,step+1});
    30. st[xx][yy]=1;
    31. }
    32. }
    33. }
    34. }
    35. int main() {
    36. cin>>n;
    37. for(int i=0;i
    38. for(int j=0;j>mp[i][j];
    39. }
    40. st[0][0]=1;
    41. for(int i=0;i
    42. for(int j=0;j
    43. if(mp[i][j]=='A'){
    44. bfs(i,j);break;
    45. }
    46. }
    47. }
    48. if(flag)
    49. cout<
    50. else cout<<-1;
    51. }

  • 相关阅读:
    博弈论(Nim游戏 , 有向图游戏)
    ESB优势2019-架构师(六十二)
    使用 Azure 静态 Web 应用服务免费部署 Hexo 博客
    zabbix6.0 部署配置
    Python实现直方图梯度提升分类模型(HistGradientBoostingClassifier算法)并基于网格搜索进行优化同时绘制PDP依赖图项目实战
    两步随机接入机制的深度解析和未来增强
    C语言实现扫雷游戏(分解代码,超级详细,无压力)
    Selenium基础 — POM设计模式(一)
    新人学习C++——VS2017报错windows SDK 8.1找不到_终于解决了
    Diffusers中基于Stable Diffusion的哪些图像操作
  • 原文地址:https://blog.csdn.net/qq_63128300/article/details/136345554
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号