403. 青蛙过河

一只青蛙想要过河。 假定河流被等分为 x 个单元格,并且在每一个单元格内都有可能放有一石子(也有可能没有)。 青蛙可以跳上石头,但是不可以跳入水中。

给定石子的位置列表(用单元格序号升序表示), 请判定青蛙能否成功过河(即能否在最后一步跳至最后一个石子上)。 开始时, 青蛙默认已站在第一个石子上,并可以假定它第一步只能跳跃一个单位(即只能从单元格1跳至单元格2)。

如果青蛙上一步跳跃了 k 个单位,那么它接下来的跳跃距离只能选择为 k - 1、k 或 k + 1个单位。 另请注意,青蛙只能向前方(终点的方向)跳跃。

请注意:

石子的数量 ≥ 2 且 < 1100;

每一个石子的位置序号都是一个非负整数,且其 < 231;

第一个石子的位置永远是0。

示例 1:

[0,1,3,5,6,8,12,17]

总共有8个石子。

第一个石子处于序号为0的单元格的位置, 第二个石子处于序号为1的单元格的位置,

第三个石子在序号为3的单元格的位置, 以此定义整个数组…

最后一个石子处于序号为17的单元格的位置。

返回 true。即青蛙可以成功过河,按照如下方案跳跃:

跳1个单位到第2块石子, 然后跳2个单位到第3块石子, 接着

跳2个单位到第4块石子, 然后跳3个单位到第6块石子,

跳4个单位到第7块石子, 最后,跳5个单位到第8个石子(即最后一块石子)。

示例 2:

[0,1,2,3,4,8,9,11]

返回 false。青蛙没有办法过河。

这是因为第5和第6个石子之间的间距太大,没有可选的方案供青蛙跳跃过去。

PS:

大佬思路,巧用API

class Solution {

//DFS版把能走得都走了,找不到指定位置得石头就返回

//我不能倒着走过起点

public boolean canCross(int[] stones) {

for(int i=1;i

if(stones[i]>stones[i-1]+i)

return false;

return dfs(stones,0,1);

}

public boolean dfs(int[] stones,int index,int v){

if(index<0 || v<1)

return false;

return index==stones.length-1||(index>0 && dfs(stones,Arrays.binarySearch(stones,stones[index]+v+1),v+1)) ||

dfs(stones,Arrays.binarySearch(stones,stones[index]+v),v) ||

dfs(stones,Arrays.binarySearch(stones,stones[index]+v-1),v-1);

}

}

两个各四只青蛙过河java_Java实现 LeetCode 403 青蛙过河相关推荐

  1. leetcode 403青蛙过河

    403. 青蛙过河 题目 分析 超时代码 代码1 代码2 代码3 通过代码 代码4 代码5 代码6 题目 一只青蛙想要过河. 假定河流被等分为 x 个单元格,并且在每一个单元格内都有可能放有一石子(也 ...

  2. Java实现 LeetCode 403 青蛙过河

    403. 青蛙过河 一只青蛙想要过河. 假定河流被等分为 x 个单元格,并且在每一个单元格内都有可能放有一石子(也有可能没有). 青蛙可以跳上石头,但是不可以跳入水中. 给定石子的位置列表(用单元格序 ...

  3. 两个各四只青蛙过河java_趣味算法——青蛙过河(JAVA)

    /*** 青蛙过河 *@authorrubekid **/ public classRiverFrog {public static final int LEFT_FROG = -1;public s ...

  4. leetcode 403. 青蛙过河(dp)

    一只青蛙想要过河. 假定河流被等分为若干个单元格,并且在每一个单元格内都有可能放有一块石子(也有可能没有). 青蛙可以跳上石子,但是不可以跳入水中. 给你石子的位置列表 stones(用单元格序号 升 ...

  5. leetcode 403.青蛙过河 C,C++超详细解释

    一只青蛙想要过河. 假定河流被等分为若干个单元格,并且在每一个单元格内都有可能放有一块石子(也有可能没有). 青蛙可以跳上石子,但是不可以跳入水中. 给你石子的位置列表 stones(用单元格序号升序 ...

  6. java青蛙过河打字_趣味算法——青蛙过河(JAVA)

    青蛙过河是一个非常有趣的智力游戏,其大意如下: 一条河之间有若干个石块间隔,有两队青蛙在过河,每队有3只青蛙,这些青蛙只能向前移动,不能向后移动,且一次只能有一只青蛙向前移动.在移动过程中,青蛙可以向 ...

  7. 青蛙爬井c语言编程,青蛙过河(ACM)

    青蛙过河(ACM) 青蛙过河 Time Limit:1000MS Memory Limit:32767K Total Submit:84 Accepted:51 Description 一条小溪尺寸不 ...

  8. 三个点在同一个半圆的概率_求解四只鸭子在同一半圆池塘的概率

    问题模型 有四只鸭子,随机分布在圆形的池塘中,请问四只鸭子同时处于同一个半圆的概率有多大? 统计模拟 使用计算机进行大量的随机实验,统计推断出未知变量的概率.我们将进行100万次独立采样试验,每次试验 ...

  9. TCP 的三次握手+两次交换+四次挥手

    目录 1.TCP 的三次握手+两次交换+四次挥手 1.1.三次握手 1.1.1.流程 1.1.2.两次握手为什么不可以? 1.1.3.第一次握手是否可以携带数据? 1.1.4.第二次握手是否可以携带数 ...

最新文章

  1. oracle 伪列访问序列,Oracle数据库对象,同义词、序列、视图、索引
  2. 定位(positioning)
  3. expressjs路由匹配规则
  4. python 中文查找_使用python和regex查找字符串中的所有中文文本
  5. mybatis的学习笔记01
  6. c# 设计原则需要学习吗_向最好的学习:产品设计原则
  7. DeepMind最新研究:如何将「大语言模型」 训练到最优?
  8. spring事务管理几种方式(转)
  9. 基于深度卷积神经网络的玉米病害实时识别检测系统
  10. io 错误: socket closed_Tomcat NIO(9)IO线程Overall流程和关键类
  11. 交流电机数字控制系统_干货 | 简述伺服电机和步进电机的六大性能差异
  12. Sass含中文目录编译报错
  13. 在Android中使用自带API操作Json
  14. 视觉开发应用1- 机器视觉基本知识之工业相机
  15. Arango db 快速入门
  16. Unity自定义Script模板
  17. 程序猿12个人艰不拆的真相
  18. 闲赋在家的猿们、接下来怎么走?
  19. PHP连接并使用人大金仓数据库kingbase
  20. Linux使用Wine安装腾讯TIM

热门文章

  1. 关于使用SXSSFWorkbook对象下载excel文件,打开文件后excel文件损坏
  2. win10家庭版调出组策略(gpedit.msc)要求的函数不受支持
  3. iPad/iPhone内存管理四之viewDidUnload/dealloc详细解说
  4. Bitly发布趋势链接搜索引擎Realtime
  5. c语言 楼盘查询系统,专业楼盘部模型
  6. 简述卡西欧5800p计算机,fx5800p
  7. python绝对方向角度值_哪个选项是turtle绘图中角度坐标系的绝对0度方向?_学小易找答案...
  8. 我来读代码之三(d-podium)
  9. 非计算机专业有前景吗,十大最有前景的专业,第一名居然不是计算机
  10. u盘提示格式化怎么修复教程