leetcode--55--跳跃游戏

2023-11-17

题目描述:

  给定一个非负整数数组,你最初位于数组的第一个位置。数组中的每个元素代表你在该位置可以跳跃的 最大长度 。判断你是否能够到达最后一个位置。

示例 1:

输入: [2,3,1,1,4]
输出: true
解释: 我们可以先跳 1 步,从位置 0 到达 位置 1, 然后再从位置 1 跳 3 步到达最后一个位置。

示例 2:

输入: [3,2,1,0,4]
输出: false
解释: 无论怎样,你总会到达索引为 3 的位置。但该位置的最大跳跃长度是 0 , 所以你永远不可能到达最后一个位置。


解题思路1:

1、构建一个list来存储每一个索引位置最远能走到的位置
2、遍历nums,如果元素的索引位置比当前最长能走到的位置远,说明这个索引位置就已经到达不了了


代码1:

Python代码:

class Solution(object):
    def canJump(self, nums):
        """
        :type nums: List[int]
        :rtype: bool
        """
        if not nums:  # 判断是否为空
            return True
        ls = []
        for index,num in enumerate(nums):
            ls.append(index+num)
        size = len(nums)

        longest = 0
        for index in range(size):
            if longest >= size-1:
                break
            if index > longest:  # 当前的位置下标已经超出了能够走到的最远位置
                break
            longest = max(longest, ls[index])

        return longest >= size-1   # 返回True或者False

s = Solution()
List = [2, 3, 1, 1, 4]
print(s.canJump(List))

结果为: True

代码精简:

class Solution:
    def canJump(self, nums):
        size, longest = len(nums), 0
        for i in range(size):
            if i <= longest:
                longest = max(longest, i + nums[i])
                if longest >= size - 1:
                    return True
        return False

C++代码:

class Solution {
public:
    bool canJump(vector<int>& nums) {
        int size = nums.size();
        if(size==0){
            return true;
        }
        vector<int> ls;
        for (int i=0; i<size; i++){
            ls.push_back(i+nums[i]);
        }

        int longest = 0;
        for (int j=0; j<size; j++){
            if (longest>=size-1){
                return true;
            }
            if(j > longest){
                break;
            }
            longest = max(longest, ls[j]);
        }
        return longest>=size-1;
    }
};

解题思路2:

  返回true有两种情况,一种是刚好跳到最后一个位置上,一种是超过最后一个位置。因为这题不需要求出每次跳的步数,只需要知道能否跳到最后。所以这两种情况其实就是一种。

1. 定义max用来存放当前能跳的最远距离。

2. i从0开始遍历,每到一个位置都判断max的值是否大于i。
2.1   如果小于 i 说明当前的最大步数不足以走到i位置,则直接返回false
2.2   否则,让当前i位置能走的最大步数和max比较。让max重新赋值。

代码2:

#include<iostream>
using namespace std;
bool canJump(int* nums, int numsSize) {
    int max=0;
    for(int i=0;i<numsSize;i++){
        if(i>max){
            return false;
        }else{
            max=max>(nums[i]+i)?max:(nums[i]+i);
        }
    }
    return true;
}
int main(){
	int nums[5] = { 2,3,1,1,4 };

	int len = sizeof(nums) / sizeof(nums[0]); // len = 20/4

	if (canJump(nums, len)){
		cout << "true" << endl;
	}
	else{
		cout << "false" << endl;
	}
	return 0;
}

代码3:

/*自顶向下的动态规划*/
#include<iostream>
using namespace std;
int *mark;//标记数组,表示mark[i]是否可以到达最后一个节点,是为1,否为-1
int min(int a, int b){
	return a < b ? a : b;
}
bool dfs(int *nums, int p,int len){
	if (mark[p] != 0){
		return mark[p] == 1 ? true : false;
	}
	int bigjump = min(nums[p] + p, len - 1);//可以跳到的下一个节点的下标最大值
	for (int next = p+1; next <= bigjump; next++){//next是下一个节点
		if (dfs(nums, next, len) == true){
			mark[next] = 1;
			return true;
		}
	}
	mark[p] = -1;//否则p不可以跳到结尾
	return false;
}
int main(){
	int nums[5] = { 3, 2, 1, 0, 4 };
	int len = sizeof(nums) / sizeof(nums[0]);  // len = 20/4
	mark = new int[len];
	for (int i = 0; i < len; i++){
		mark[i] = 0;
	}
	mark[len - 1] = 1; // mark数组为{0,0,0,0,1}
	if (dfs(nums, 0, len)){
		cout << "true" << endl;
	}
	else{
		cout << "false" << endl;
	}
	return 0;
}

参考链接:

[1]. LeetCode-55-跳跃游戏
[2]. LeetCode—55.跳跃游戏
[3]. leetcode–55–跳跃游戏

题目链接:https://leetcode-cn.com/problems/jump-game

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

leetcode--55--跳跃游戏 的相关文章

  • WcfSvcHost 的跨域异常

    对于另一个跨域问题 我深表歉意 我一整天都在与这个问题作斗争 现在已经到了沸腾的地步 我有一个 Silverlight 应用程序项目 SLApp1 一个用于托管 Silverlight SLApp1 Web 的 Web 项目和 WCF 项目
  • 结构体的内存大小不同?

    为什么第一种情况不是12 测试环境 最新版本的 gcc 和 clang 64 位 Linux struct desc int parts int nr sizeof desc Output 16 struct desc int parts
  • 为什么这个字符串用AesCryptoServiceProvider第二次解密时不相等?

    我在 C VS2012 NET 4 5 中的文本加密和解密方面遇到问题 具体来说 当我加密并随后解密字符串时 输出与输入不同 然而 奇怪的是 如果我复制加密的输出并将其硬编码为字符串文字 解密就会起作用 以下代码示例说明了该问题 我究竟做错
  • Numpy 优化

    我有一个根据条件分配值的函数 我的数据集大小通常在 30 50k 范围内 我不确定这是否是使用 numpy 的正确方法 但是当数字超过 5k 时 它会变得非常慢 有没有更好的方法让它更快 import numpy as np N 5000
  • C# xml序列化必填字段

    我需要将一些字段标记为需要写入 XML 文件 但没有成功 我有一个包含约 30 个属性的配置类 这就是为什么我不能像这样封装所有属性 public string SomeProp get return someProp set if som
  • 如何将 PIL 图像转换为 NumPy 数组?

    如何转换 PILImage来回转换为 NumPy 数组 这样我就可以比 PIL 进行更快的像素级转换PixelAccess允许 我可以通过以下方式将其转换为 NumPy 数组 pic Image open foo jpg pix numpy
  • 如何在当前 Visual Studio 主机内的 Visual Studio 扩展中调试使用 Roslyn 编译的代码?

    我有一个 Visual Studio 扩展 它使用 Roslyn 获取当前打开的解决方案中的项目 编译它并从中运行方法 程序员可以修改该项目 我已从当前 VisualStudioWorkspace 成功编译了 Visual Studio 扩
  • Python:计算字典的重复值

    我有一本字典如下 dictA unit1 test1 alpha unit1 test2 beta unit2 test1 alpha unit2 test2 gamma unit3 test1 delta unit3 test2 gamm
  • 相当于Linux中的导入库

    在 Windows C 中 当您想要链接 DLL 时 您必须提供导入库 但是在 GNU 构建系统中 当您想要链接 so 文件 相当于 dll 时 您就不需要链接 为什么是这样 是否有等效的 Windows 导入库 注意 我不会谈论在 Win
  • 在python中,如何仅搜索所选子字符串之前的一个单词

    给定文本文件中的长行列表 我只想返回紧邻其前面的子字符串 例如单词狗 描述狗的单词 例如 假设有这些行包含狗 hotdog big dog is dogged dog spy with my dog brown dogs 在这种情况下 期望
  • 使用基于正则表达式的部分匹配来选择 Pandas 数据帧的子数据帧

    我有一个 Pandas 数据框 它有两列 一列 进程参数 列 包含字符串 另一列 值 列 包含相应的浮点值 我需要过滤出部分匹配列 过程参数 中的一组键的子数据帧 并提取与这些键匹配的数据帧的两列 df pd DataFrame Proce
  • C++ 中的 include 和 using 命名空间

    用于使用cout 我需要指定两者 include
  • 协方差矩阵的对角元素不是 1 pandas/numpy

    我有以下数据框 A B 0 1 5 1 2 6 2 3 7 3 4 8 我想计算协方差 a df iloc 0 values b df iloc 1 values 使用 numpy 作为 cov numpy cov a b I get ar
  • DotNetZip:如何提取文件,但忽略zip文件中的路径?

    尝试将文件提取到给定文件夹 忽略 zip 文件中的路径 但似乎没有办法 考虑到其中实现的所有其他好东西 这似乎是一个相当基本的要求 我缺少什么 代码是 using Ionic Zip ZipFile zf Ionic Zip ZipFile
  • Spark.read 在 Databricks 中给出 KrbException

    我正在尝试从 databricks 笔记本连接到 SQL 数据库 以下是我的代码 jdbcDF spark read format com microsoft sqlserver jdbc spark option url jdbc sql
  • 在OpenGL中,我可以在坐标(5, 5)处精确地绘制一个像素吗?

    我所说的 5 5 正是指第五行第五列 我发现使用屏幕坐标来绘制东西非常困难 OpenGL 中的所有坐标都是相对的 通常范围从 1 0 到 1 0 为什么阻止程序员使用屏幕坐标 窗口坐标如此严重 最简单的方法可能是通过以下方式设置投影以匹配渲
  • 改变字典的哈希函数

    按照此question https stackoverflow com questions 37100390 towards understanding dictionaries 我们知道两个不同的字典 dict 1 and dict 2例
  • MySQL Connector C/C API - 使用特殊字符进行查询

    我是一个 C 程序 我有一个接受域名参数的函数 void db domains query char name 使用 mysql query 我测试数据库中是否存在域名 如果不是这种情况 我插入新域名 char query 400 spri
  • 指针和内存范围

    我已经用 C 语言编程有一段时间了 但对 C 语言还是很陌生 有时我对 C 处理内存的方式感到困惑 考虑以下有效的 C 代码片段 const char string void where is this pointer variable l
  • Mono 应用程序在非阻塞套接字发送时冻结

    我在 debian 9 上的 mono 下运行一个服务器应用程序 大约有 1000 2000 个客户端连接 并且应用程序经常冻结 CPU 使用率达到 100 我执行 kill QUIT pid 来获取线程堆栈转储 但它总是卡在这个位置

随机推荐

  • Python基础学完了再学什么?

    Python基础学完了再学什么 基础阶段学完Python 基础语法 python 容器 函数和文件操作 面向对象 python编程和web基础 Linux 操作系统多任务编程 Python 网络编程 静态 web 服务器 HTML CSS
  • Linux定时清理30天前的Tomcat日志脚本

    一 在tomcat的log路径下新建 sh脚本文件clean sh 内容如下 bin bash logs path mnt tomcat apache tomcat 8 5 23 logs find logs path mtime 30 n
  • 目标检测算法——GFocal loss

    https zhuanlan zhihu com p 147691786
  • 命令行传参

    命令行传参 运行一个程序时传递给它消息 依靠命令行参数给main 函数实现 public class mainTest public static void main String args for int i 0 i lt args le
  • windows上pycharm远程调试GPU服务器报错 Cannot load cudnn shared library

    参考 Pycharm问题 pycharm远程调试报错ImportError libcusolver so 9 0 cannot open shared object file 原因 LD LIBRARY PATH 环境变量pycham没有找
  • 解决uni-app微信小程序底部input输入框,键盘弹起时页面整体上移问题

    一 存在的问题 微信小程序聊天界面 当input 框获取焦点时会自动调起手机键盘 当键盘弹起时 会导致页面整体上移 页面头信息会消失不见 二 需要实现的效果 1 键盘弹出时 底部的输入框跟随键盘上弹 2 页面头固定在顶部不动 3 聊天信息区
  • s-des密码算法实现

    实验二 S DES算法实现 一 S DES算法分析 1 Simplified DES方案 简称S DES方案 它是一个供教学而非安全的加密算法 它与DES的特性和结构类似 但参数小 加密算法涉及五个函数 1 初始置换IP initial p
  • Flutter使用SharedPreferences一直报初始化的问题

    以下代码可以解决 定义一个全局的存储对象 late SharedPreferences sp void main async 加入后可正常使用 WidgetsFlutterBinding ensureInitialized 初始化存储 sp
  • C#readonly关键字

    readonly是一种常量修饰符 区别于const 分别进行记录 先说const const是静态常量或者叫编译时常量 是指编译器在编译时候会对常量进行解析 并将常量的值替换成初始化的那个值 必须在声明的时候初使化 const 关键字声明的
  • Java工程师学快速Python(3)----- 模块、包、库 输入 输出

    简单的说一个 py文件就是一个模块 多个 py文件整合成一个包 各种包的集合就是库 import 语句 想使用 Python 源文件 只需在另一个源文件里执行 import 语句 语法如下 import module1 module2 mo
  • Endnote显示cannot edit range(无法编辑range)

    1 方法1 这种问题的原因可能是选择了 Convert to Unformatted Citations 正确的方法应该是在Word中选择endnote页面 Convert Word Citations to EndNote 然后再 Upd
  • 全栈之前端

    欢迎关注 全栈工程师修炼指南 公众号 设为 星标 每天带你 基础入门 到 进阶实践 再到 放弃学习 专注 企业运维实践 网络安全 系统运维 应用开发 物联网实战 全栈文章 等知识分享 花开堪折直须折 莫待无花空折枝 作者主页 https w
  • 如何在word文档中添加两个目录

    由于需要在一个word文档中添加两个目录 第一个目录表示文章前半部分的内容 第二个目录表示后半部分的内容 对于word不太熟悉的我经过一番折腾之后终于搞定了 在此记录一下 原理 将word文本划分成两个域 而每个域里的标题可以看做是不同的书
  • echarts 关系图 参数_Echarts关系图(使用重力图)

    首先展示一下该关系图效果 很简单的关系图 不过其中经历不少波折 使用的是echarts2 现在贴出代码 1 functiondos 2 var name document getElementById name value 3 post G
  • Pandas玩转数据透视表,用它就够了~

    大家好 我是丁小杰 对于数据透视表 相信对于 Excel 比较熟悉的小伙伴都知道如何使用它 并了解它的强大之处 而在pandas中要实现数据透视就要用到pivot table了 导入示例数据 首先导入演示的数据集 import pandas
  • 【C++】STL之栈(stack)介绍

    栈 stack 栈是一种运算受限的线性表 限定仅在表尾进行插入和删除的操作 插入 push 弹出 pop 其特性就是先进后出 即先插入的元素最后才能弹出 大家可以把栈想象成一个弹夹 你只能在顶层一颗一颗装入子弹 先装的子弹在最底层 打出时也
  • 学什么副业前景好?学一个什么副业比较好?自学副业有哪些?

    很多公司不希望自己的员工做副业 主要还是担心员工做副业会影响到工作 如果员工在下班后的空闲时间搞搞副业 那公司就没法管了呀 你平时下班后的空闲时间都做些什么 学什么副业前景好 1 自学ps 现在很多影楼 摄影工作室 电商商家会把自己拍摄的照
  • JVM调优参数归纳汇总

    GC通常参数 Xss 每个线程的栈大小 Xms 初始堆大小 默认物理内存的1 64 Xmx 最大堆大小 默认物理内存的1 4 Xmn 新生代大小 XX ParallelGCThreads 指定GC工作的线程数量 XX MinHeapSize
  • 查询局域网电脑的IP,端口号,MAC地址

    网上看到很多都是使用nmap工具 这个工具我没有使用过 我自己实现nmap工具的功能 首先我们查询局域网内有哪些电脑是alive的 下面我写了一个脚本 ping sh 这样局域网内哪些电脑的ip是alive的就可以知道 下面来查看对于IP的
  • leetcode--55--跳跃游戏

    题目描述 给定一个非负整数数组 你最初位于数组的第一个位置 数组中的每个元素代表你在该位置可以跳跃的 最大长度 判断你是否能够到达最后一个位置 示例 1 输入 2 3 1 1 4 输出 true 解释 我们可以先跳 1 步 从位置 0 到达