欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java跳躍游戲?qū)嵗骖}解決思路詳解

 更新時間:2022年10月21日 09:26:31   作者:劉婉晴  
這篇文章主要介紹了Java跳躍游戲,總的來說這并不是一道難題,那為什么要拿出這道題介紹?拿出這道題真正想要傳達(dá)的是解題的思路,以及不斷優(yōu)化探尋最優(yōu)解的過程。希望通過這道題能給你帶來一種解題優(yōu)化的思路

變式題—跳躍游戲 I

一、題目描述

給定一個非負(fù)整數(shù)數(shù)組 nums ,你最初位于數(shù)組的 第一個下標(biāo) 。數(shù)組中的每個元素代表你在該位置可以跳躍的最大長度。判斷你是否能夠到達(dá)最后一個下標(biāo)。

來源:https://leetcode.cn/problems/jump-game/

示例:

二、思路

本題可以使用貪心法解決,對每個能到達(dá)的位置(可覆蓋到的位置),計算其每次能覆蓋的最大長度,判斷最大長度是否能達(dá)到數(shù)組尾即可。

圖解:

三、代碼

    // 跳躍游戲問題,判斷能否達(dá)到數(shù)組尾
    public boolean canJump(int[] nums) {
        int len = nums.length;
        int cover = 0; // 初始位置為第一個點
        for(int i=0; i<=cover; i++){
            cover = Math.max(cover, i + nums[i]); // 更新最大 cover
            if(cover >= (len - 1)){ // 可達(dá)到最后的位置
                return true;
            }
        }
        return false;
    }

變式題—跳躍游戲 II

一、題目描述

給你一個非負(fù)整數(shù)數(shù)組 nums ,你最初位于數(shù)組的第一個位置。數(shù)組中的每個元素代表你在該位置可以跳躍的最大長度。你的目標(biāo)是使用最少的跳躍次數(shù)到達(dá)數(shù)組的最后一個位置。假設(shè)你總是可以到達(dá)數(shù)組的最后一個位置。

鏈接:https://leetcode.cn/problems/jump-game-ii

二、思路

本題只有一個關(guān)鍵點,那就是什么時候更新 ans,使得結(jié)果是最小跳躍步數(shù)

回答:當(dāng)前位置為最大 cover 時,需要更新 ans,按這種情況更新的 ans 為最小跳躍步數(shù)

三、代碼

// 版本一
class Solution {
    public int jump(int[] nums) {
        if (nums == null || nums.length == 0 || nums.length == 1) {
            return 0;
        }
        //記錄跳躍的次數(shù)
        int count=0;
        //當(dāng)前的覆蓋最大區(qū)域
        int curDistance = 0;
        //最大的覆蓋區(qū)域
        int maxDistance = 0;
        for (int i = 0; i < nums.length; i++) {
            //在可覆蓋區(qū)域內(nèi)更新最大的覆蓋區(qū)域
            maxDistance = Math.max(maxDistance,i+nums[i]);
            //說明當(dāng)前一步,再跳一步就到達(dá)了末尾
            if (maxDistance>=nums.length-1){
                count++;
                break;
            }
            //走到當(dāng)前覆蓋的最大區(qū)域時,更新下一步可達(dá)的最大區(qū)域
            if (i==curDistance){
                curDistance = maxDistance;
                count++;
            }
        }
        return count;
    }
}

到此這篇關(guān)于Java跳躍游戲?qū)嵗骖}解決思路詳解的文章就介紹到這了,更多相關(guān)Java跳躍游戲內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 解決lambda表達(dá)式內(nèi)出現(xiàn)異常無法throw拋出的問題

    解決lambda表達(dá)式內(nèi)出現(xiàn)異常無法throw拋出的問題

    這篇文章主要介紹了lambda表達(dá)式內(nèi)出現(xiàn)異常無法throw拋出的解決,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-09-09
  • Java中多種循環(huán)Map的常見方式詳解

    Java中多種循環(huán)Map的常見方式詳解

    Java中的Map是一種鍵值對存儲的數(shù)據(jù)結(jié)構(gòu),其中每個鍵都唯一,與一個值相關(guān)聯(lián),下面這篇文章主要給大家介紹了關(guān)于Java中多種循環(huán)Map的常見方式,文中給出了詳細(xì)的代碼示例,需要的朋友可以參考下
    2024-01-01
  • 重新認(rèn)識Java的System.in

    重新認(rèn)識Java的System.in

    今天小編就為大家分享一篇關(guān)于重新認(rèn)識Java的System.in,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2018-12-12
  • spring+springmvc+mybatis+maven入門實戰(zhàn)(超詳細(xì)教程)

    spring+springmvc+mybatis+maven入門實戰(zhàn)(超詳細(xì)教程)

    這篇文章主要介紹了spring+springmvc+mybatis+maven入門實戰(zhàn)(超詳細(xì)教程),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-05-05
  • 使用Spring Data R2DBC +Postgres實現(xiàn)增刪改查功能

    使用Spring Data R2DBC +Postgres實現(xiàn)增刪改查功能

    這篇文章主要介紹了使用Spring Data R2DBC +Postgres實現(xiàn)增刪改查功能,本文通過兩種方法給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-03-03
  • Java Collections.sort()排序代碼案例

    Java Collections.sort()排序代碼案例

    這篇文章主要介紹了Java Collections.sort()排序代碼案例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-02-02
  • Javabean簡介_動力節(jié)點Java學(xué)院整理

    Javabean簡介_動力節(jié)點Java學(xué)院整理

    這篇文章主要介紹了Javabean簡介,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-07-07
  • Java日常練習(xí)題,每天進(jìn)步一點點(60)

    Java日常練習(xí)題,每天進(jìn)步一點點(60)

    下面小編就為大家?guī)硪黄狫ava基礎(chǔ)的幾道練習(xí)題(分享)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧,希望可以幫到你
    2021-08-08
  • Java Spring Boot實現(xiàn)簡易掃碼登錄詳解

    Java Spring Boot實現(xiàn)簡易掃碼登錄詳解

    這篇文章主要為大家詳細(xì)介紹了java Spring Boot實現(xiàn)app掃碼登錄功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2021-09-09
  • Spring注入Map集合實現(xiàn)策略模式詳解

    Spring注入Map集合實現(xiàn)策略模式詳解

    這篇文章主要介紹了Spring注入Map集合實現(xiàn)策略模式詳解,Spring提供通過@Resource注解將相同類型的對象注入到Map集合,并將對象的名字作為key,對象作為value封裝進(jìn)入Map,需要的朋友可以參考下
    2023-11-11

最新評論