Java跳躍游戲?qū)嵗骖}解決思路詳解
變式題—跳躍游戲 I
一、題目描述
給定一個(gè)非負(fù)整數(shù)數(shù)組 nums ,你最初位于數(shù)組的 第一個(gè)下標(biāo) 。數(shù)組中的每個(gè)元素代表你在該位置可以跳躍的最大長(zhǎng)度。判斷你是否能夠到達(dá)最后一個(gè)下標(biāo)。
來(lái)源:https://leetcode.cn/problems/jump-game/
示例:

二、思路
本題可以使用貪心法解決,對(duì)每個(gè)能到達(dá)的位置(可覆蓋到的位置),計(jì)算其每次能覆蓋的最大長(zhǎng)度,判斷最大長(zhǎng)度是否能達(dá)到數(shù)組尾即可。
圖解:

三、代碼
// 跳躍游戲問(wèn)題,判斷能否達(dá)到數(shù)組尾
public boolean canJump(int[] nums) {
int len = nums.length;
int cover = 0; // 初始位置為第一個(gè)點(diǎn)
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
一、題目描述
給你一個(gè)非負(fù)整數(shù)數(shù)組 nums ,你最初位于數(shù)組的第一個(gè)位置。數(shù)組中的每個(gè)元素代表你在該位置可以跳躍的最大長(zhǎng)度。你的目標(biāo)是使用最少的跳躍次數(shù)到達(dá)數(shù)組的最后一個(gè)位置。假設(shè)你總是可以到達(dá)數(shù)組的最后一個(gè)位置。
鏈接:https://leetcode.cn/problems/jump-game-ii
二、思路
本題只有一個(gè)關(guān)鍵點(diǎn),那就是什么時(shí)候更新 ans,使得結(jié)果是最小跳躍步數(shù)
回答:當(dāng)前位置為最大 cover 時(shí),需要更新 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]);
//說(shuō)明當(dāng)前一步,再跳一步就到達(dá)了末尾
if (maxDistance>=nums.length-1){
count++;
break;
}
//走到當(dāng)前覆蓋的最大區(qū)域時(shí),更新下一步可達(dá)的最大區(qū)域
if (i==curDistance){
curDistance = maxDistance;
count++;
}
}
return count;
}
}到此這篇關(guān)于Java跳躍游戲?qū)嵗骖}解決思路詳解的文章就介紹到這了,更多相關(guān)Java跳躍游戲內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
SpringCloud服務(wù)注冊(cè)和發(fā)現(xiàn)組件Eureka
對(duì)于微服務(wù)的治理而言,其核心就是服務(wù)的注冊(cè)和發(fā)現(xiàn)。在SpringCloud 中提供了多種服務(wù)注冊(cè)與發(fā)現(xiàn)組件,官方推薦使用Eureka。本篇文章,我們來(lái)講解springcloud的服務(wù)注冊(cè)和發(fā)現(xiàn)組件,感興趣的可以了解一下2021-05-05
SpringBoot對(duì)Filter過(guò)濾器中的異常進(jìn)行全局處理方案詳解
這篇文章主要介紹了SpringBoot對(duì)Filter過(guò)濾器中的異常進(jìn)行全局處理,在SpringBoot中我們通過(guò) @ControllerAdvice 注解和 @ExceptionHandler注解注冊(cè)了全局異常處理器,需要的朋友可以參考下2023-09-09
java使用內(nèi)存數(shù)據(jù)庫(kù)ssdb的步驟
這篇文章主要介紹了java使用內(nèi)存數(shù)據(jù)庫(kù)ssdb的步驟,幫助大家更好的理解和使用Java,感興趣的朋友可以了解下2020-12-12
細(xì)數(shù)java中Long與Integer比較容易犯的錯(cuò)誤總結(jié)
下面小編就為大家?guī)?lái)一篇細(xì)數(shù)java中Long與Integer比較容易犯的錯(cuò)誤總結(jié)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-01-01
Spring DATA JPA 中findAll 進(jìn)行OrderBy方式
這篇文章主要介紹了Spring DATA JPA 中findAll 進(jìn)行OrderBy方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-11-11
Java利用Geotools從DEM數(shù)據(jù)中讀取指定位置的高程信息全過(guò)程
Geotools作為一款功能強(qiáng)大且開(kāi)源的地理工具庫(kù),為地理數(shù)據(jù)的處理和分析提供了豐富的類(lèi)庫(kù)和便捷的接口,能夠很好地滿(mǎn)足從DEM數(shù)據(jù)中讀取高程信息這一實(shí)戰(zhàn)需求,本文將深入講解如何利用Geotools從獲取DEM數(shù)據(jù)到成功讀取指定位置高程信息的全過(guò)程,需要的朋友可以參考下2025-03-03
Java多線(xiàn)程之同步工具類(lèi)CyclicBarrier
這篇文章主要介紹Java多線(xiàn)程之同步工具類(lèi)CyclicBarrier,它是一個(gè)同步工具類(lèi),它允許一組線(xiàn)程互相等待,直到達(dá)到某個(gè)公共屏障點(diǎn),支持一個(gè)可選的Runnable命令,在一組線(xiàn)程中的最后一個(gè)線(xiàn)程到達(dá)之后,該命令只在每個(gè)屏障點(diǎn)運(yùn)行一次。下面來(lái)看文章具體內(nèi)容2021-10-10
java使用Filter實(shí)現(xiàn)自動(dòng)登錄的方法
這篇文章主要為大家詳細(xì)介紹了java使用Filter實(shí)現(xiàn)自動(dòng)登錄的方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-04-04

