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)文章
解決lambda表達(dá)式內(nèi)出現(xiàn)異常無(wú)法throw拋出的問(wèn)題
這篇文章主要介紹了lambda表達(dá)式內(nèi)出現(xiàn)異常無(wú)法throw拋出的解決,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-09-09Java中多種循環(huán)Map的常見(jiàn)方式詳解
Java中的Map是一種鍵值對(duì)存儲(chǔ)的數(shù)據(jù)結(jié)構(gòu),其中每個(gè)鍵都唯一,與一個(gè)值相關(guān)聯(lián),下面這篇文章主要給大家介紹了關(guān)于Java中多種循環(huán)Map的常見(jiàn)方式,文中給出了詳細(xì)的代碼示例,需要的朋友可以參考下2024-01-01spring+springmvc+mybatis+maven入門實(shí)戰(zhàn)(超詳細(xì)教程)
這篇文章主要介紹了spring+springmvc+mybatis+maven入門實(shí)戰(zhàn)(超詳細(xì)教程),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2019-05-05使用Spring Data R2DBC +Postgres實(shí)現(xiàn)增刪改查功能
這篇文章主要介紹了使用Spring Data R2DBC +Postgres實(shí)現(xiàn)增刪改查功能,本文通過(guò)兩種方法給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-03-03Javabean簡(jiǎn)介_(kāi)動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
這篇文章主要介紹了Javabean簡(jiǎn)介,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-07-07Java日常練習(xí)題,每天進(jìn)步一點(diǎn)點(diǎn)(60)
下面小編就為大家?guī)?lái)一篇Java基礎(chǔ)的幾道練習(xí)題(分享)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧,希望可以幫到你2021-08-08Java Spring Boot實(shí)現(xiàn)簡(jiǎn)易掃碼登錄詳解
這篇文章主要為大家詳細(xì)介紹了java Spring Boot實(shí)現(xiàn)app掃碼登錄功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來(lái)幫助2021-09-09Spring注入Map集合實(shí)現(xiàn)策略模式詳解
這篇文章主要介紹了Spring注入Map集合實(shí)現(xiàn)策略模式詳解,Spring提供通過(guò)@Resource注解將相同類型的對(duì)象注入到Map集合,并將對(duì)象的名字作為key,對(duì)象作為value封裝進(jìn)入Map,需要的朋友可以參考下2023-11-11