码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 【算法】过桥


    ✨题目链接:

    过桥


    ✨题目描述 

     

    ✨输入描述:

    第一行一个数n(2≤n≤2000)
    接下来一行n个数a[i](1≤|a[i]|≤2000)表示浮块上的数字

    ✨输出描述:

     输出一行,表示对应的答案

    ✨示例1

    📍输入

    4
    2 2 -1 2 

    📍输出

     2

    📍说明

     1跳到2,1s 2跳到4,1s 共2s 

    ✨示例2

    📍输入

     2
    -1 -2

    📍输出

     -1

    ✨解题思路

     贪心+bfs:

    • 初始化:

      • left 和 right 初始化为1,表示从第一个浮块开始。
      • ret 初始化为0,记录当前传送的步数。
    • 循环条件:

      • 当 left 小于等于 right 时,进入循环。每一轮循环表示一次传送。
    • 步数递增:

      • 每进入一次循环,步数 ret 加1。
    • 更新右边界:

      • r 初始化为 right 的当前值。
      • 遍历当前传送范围 [left, right] 内的所有浮块,计算每个浮块能到达的最远位置 arr[i] + i。
      • 更新 r 为最远的浮块位置。
    • 检查到达终点:

      • 如果最远位置 r 大于等于 n,表示可以到达或超过 n 号浮块,返回当前步数 ret。
    • 更新左右边界:

      • 更新 left 为 right + 1,表示进入下一轮传送的起点。
      • 更新 right 为当前最远位置 r。
    • 返回无法到达的情况:

      • 如果循环结束后,仍未能到达 n 号浮块,返回 -1。

    ✨代码
     

    1. #include
    2. using namespace std;
    3. const int N=2010;
    4. int n;
    5. int arr[N];
    6. int bfs()
    7. {
    8. int left=1,right=1;
    9. int ret=0;
    10. while(left<=right)
    11. {
    12. ret++;
    13. int r=right;
    14. for(int i=left;i<=right;i++)
    15. {
    16. r=max(r,arr[i]+i);
    17. if(r>=n)return ret;
    18. }
    19. left=right+1;
    20. right=r;
    21. }
    22. return -1;
    23. }
    24. int main()
    25. {
    26. cin>>n;
    27. for(int i=1;i>arr[i];
    28. cout<<bfs()<
    29. return 0;
    30. }


    ※ 如果文章对你有帮助的话,可以点赞收藏!!谢谢支持

  • 相关阅读:
    SpringBoot 整合 MyBatis-Plus
    echars 设置滚动条演示,
    一款适用于勒索病毒应急演练加解密工具
    React源码分析4-深度理解diff算法
    海格里斯四向穿梭车|为何越来越多的仓库选择使用四向穿梭车立体库?
    php花式读取文件
    linux更换常用软件的默认缓存路径(.conda, .huggingface等)
    深拷贝与浅拷贝
    什么是分支和合并(阁瑞钛伦特软件-九耶实训)
    诚信型性格分析,诚信型人格的职业发展
  • 原文地址:https://blog.csdn.net/W9940/article/details/139361978
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | 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号