百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

玩蛇(Python) - 算法练习:leetcode 55. 跳跃游戏

myzbx 2025-05-24 15:42 1 浏览

一、需求介绍:55. 跳跃游戏

1.1 输入

给你一个非负整数数组 nums, 数组中的每个元素代表你在该位置可以跳跃的最大长度。

1.2 要求

你最初位于数组的 第一个下标 。

1.3输出

判断你是否能够到达最后一个下标,如果可以,返回 true ;否则,返回 false。

1.4 前置条件(无需额外判断)

  • 1 <= nums.length <= 104
  • 0 <= nums[i] <= 105

二、需求分析设计

2.1 算法分析

1、根据当前位置的值,可以判断出来最远到达那个位置;移动到下一个位置,并刷新这个最远达到的位置,以此类推。

2、当最远到达位置超过了终点位置,那么就可以到达,返回True;反之如果到了倒数第二个位置,还未到达最后一个位置,返回False。

2.2 算法代码实现(代码自注释且有详细文字注释,还看不懂介绍异性朋友给你)

   #-*- coding:utf-8 -*-
class Solution(object):
    def canJump(self, nums):
        """
        :type nums: List[int]
        :rtype: bool
       
        #Author: ShanGouXuehui
        #Date: 2024-09-01
        #Git: https://github.com/ShanGouXueHui/PythonAlgorithm
        #Find More Python Algorithm Cases: https://m.toutiao.com/is/iYSgcfwq/
        #Personal Page: https://www.toutiao.com/c/user/token/MS4wLjABAAAAaW5663GHobdB_4icGBE0z2IJSWBSYeEAmoCfHTazjhTREfuBFo6wZCPR34-atRpn/?source=profile
        """
       
        #获得元素个数,用于后续复用
        num_of_elements = len(nums)
        #到达最远的位置, 从第一个位置开始
        reach_farest_position = 0
       
        for position_index in range(num_of_elements):
            #如果可以到达当前位置,则继续往下跳跃
            if reach_farest_position >= position_index:
                #当前位置可以到达的最远位置为position_index + nums[position_index]
                #历史最远,和本位置最远,做一个比较,保留更远的值
                reach_farest_position = max(reach_farest_position, position_index + nums[position_index])
                #如果到达终点返回True
                if reach_farest_position >= num_of_elements - 1:
                    return True
            #如果没有到达当前位置,则游戏结束
            else:
                return False
               
        #最终没有到达最后一个位置
        return False
       
if __name__ == "__main__":
    cs = Solution()
   
    # 示例 1:
    # 输入:
    nums = [2,3,1,1,4]
    # 输出:true
    # 解释:可以先跳 1 步,从下标 0 到达下标 1, 然后再从下标 1 跳 3 步到达最后一个下标。
    print('示例1: ', cs.canJump(nums))
   
    # 示例 2:
    # 输入:
    nums = [3,2,1,0,4]
    # 输出:false
    # 解释:无论怎样,总会到达下标为 3 的位置。但该下标的最大跳跃长度是 0 , 所以永远不可能到达最后一个下标。
    print('示例1: ', cs.canJump(nums))

2.3 算法结果验证

PS D:\Shangouxuehui_Git\PythonAlgorithm-main> python -u "d:\Shangouxuehui_Git\PythonAlgorithm-main\jump_game1.py"
示例1: True
示例1: False

2.4 源码下载:

https://github.com/ShanGouXueHui/PythonAlgorithm

2.5 更多Python算法合集访问

https://m.toutiao.com/is/iYSgcfwq/

##山狗学会 License Start##

转载请注明出处,"今日头条"创作者"山狗学会“ ,注明出处即授权,未注明出处罚款100万元

主页链接:山狗学会主页

##山狗学会 License End##

<script type="text/javascript" src="//mp.toutiao.com/mp/agw/mass_profit/pc_product_promotions_js?item_id=7409662537433645605"></script><script type="text/javascript" src="//mp.toutiao.com/mp/agw/mass_profit/pc_product_promotions_js?item_id=7409662537433645605"></script>

相关推荐

一步一步往上爬 可爱像素跳跃《Cuby Jump》

CliqersSdnBhd宣布旗下新作《CubyJump》已经正式在全球的iOS及Android双平台上架。该作是一款像素风格的跳跃游戏,玩家要控制萌萌哒的各种角色跃过险阻到达顶峰。玩家必须操控...

Apex英雄手游版上手实测:“味对了”,但瑜不掩瑕

大家好呀,这里是你们的小编。《Apex英雄》近日在菲律宾开启了小范围Beta测试。小编也是费尽心思,终于能够上手体验这款《Apex英雄》的手游版啦!先给出一个结论:有端游的感觉,但是还不够。《Apex...

《古墓丽影崛起》高空滑索怎么转换?高空滑索技巧分享

在《古墓丽影崛起》中,要完成高空滑索转换并解锁“滑索专家”奖杯,玩家需要掌握一定的技巧和时机。以下是一些具体的步骤和建议:一、高空滑索转换技巧芭芭雅嘎打女巫场景:在游戏中,芭芭雅嘎打女巫的场景是完成高...

第一人称跑酷游戏FOTONICA:急速奔跑的超快感

一款第一人称跑酷游戏,3年前已登陆PC端,以其绝妙的几何抽象艺术画面吸引了玩家们的目光。今夏登陆iOS平台,在原版的基础上增加了新的曲目和关卡,光怪陆离的跑酷场景不断刺激你的双眼。想玩好,首先要有...

点击类休闲游戏《跳转战士》 在跳跃中寻求厮杀快感

寿司发表于2015-12-2417:52以不断砍杀怪物从而获得经验和奖励的游戏可谓十分常见,不过近日推出的这款休闲游戏JumpWarrior《跳转战士》却采用了不断跳跃的方式来进行游玩。在这款...

FC游戏《冒险岛》1234通关结局赏析,多少玩家被卡了整整三十年

《冒险岛》系列应该是所有玩家们的共同回忆吧!就是不知道当年的你接触过哪一代呢?《冒险岛》在红白机平台发行了四部作品,在街机平台有一款名为《神奇小子》的游戏和《冒险岛》很有渊源,这在之前我们已经仔细研究...

452,跳跃游戏

给定一个非负整数数组,你最初位于数组的第一个位置。数组中的每个元素代表你在该位置可以跳跃的最大长度。判断你是否能够到达最后一个位置。示例1:输入:[2,3,1,1,4]输出:true解释:我们...

休闲游戏《跳跃山羊》:简单跳跃填色带你回温经典

Laficko发表于2015-12-0515:33经典街机游戏《Q伯特》凭借着颇具立体感的画面效果以及简单的填色玩法,在过去80年代便受到不少玩家的喜爱。如今开发商ATOOI按照这款经典...

游戏百解——跳一跳(Python自动跳跃)

跳一跳Python游戏百解。今天将教大家怎么用Python程序做一个跳一跳这个游戏的辅助工具,在后续将加入图像识别算法,让小人可以自动识别并跳到下个平台。·首先得确定两个平台之间的距离,做了一个简单的...

《幻塔》战斗体系解析:浮空闪避,动作体验如何丝滑?

前言相较于武侠、仙侠、魔幻题材而言,提起科幻类型的游戏,大部分人都会在脑海里浮现出“硬核”、“烧脑”等一系列足以劝退萌新小白的形容词。正因如此,怎样深入浅出地讲好一个科幻故事,探讨科技与人性的关系,也...

《电精》和《电神魔傀》的无敌隐身,街机游戏中的上帝模式

估计很多玩家都还分不清楚《电精》和《电神魔傀》这两款游戏吧!简单一点来说的话,《电精》就是三人版,来自SFC平台。而《电神魔傀》则是六人版,来自街机平台。当年我们在街机游戏厅中玩到的几乎都是《电精》,...

3D平台跳跃游戏《蓝精灵:梦境》发布首支预告:2024年底推出

IT之家4月29日消息,发行商Microids今日发布了3D平台跳跃游戏《蓝精灵:梦境》的首支预告。目前游戏Steam商店页面已经上线,游戏支持单人游玩,或与一名好友组队双人游玩...

黏液 - 评测:小巧有趣的平台跳跃冒险游戏

与自家的整洁程度有所不同,我反倒发现在游戏中完成清洁工作有种莫名的满足感。正因如此,《黏液(TheGunk)》对我来说有着别样的吸引力,因为它的线性战役为我提供了这样的机会,将一个被黏液覆盖的外星球...

魔兽怀旧服:熊坦跳跃的时候无躲闪?深入研究6条原理,涨知识了

一位魔兽世界TBC怀旧服的熊坦玩家在打团的时候被队友吐槽了,队友认为他的游戏习惯不好,经常跳跃导致滞空时间过长会没有躲闪。这个队友的建议让熊坦一脸懵,跳跃无躲闪这个说法他还是第一次听到,那么这位队友的...

“趣游戏”唤醒两代人的童年!课间15分钟已悄然升级到“PLUS版本”

为了响应省教育厅“2·15”专项行动的要求,新学期开学以来,南京江北新区高新实验小学的课间延长到了15分钟。如何让延长的课间既安全有序又充满活力?该校开展了校园达人“封绳榜”挑战赛,用一根小小的跳绳,...