Java跳躍游戲?qū)嵗骖}解決思路詳解
變式題—跳躍游戲 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拋出的解決,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-09-09spring+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)增刪改查功能,本文通過兩種方法給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-03-03Javabean簡介_動力節(jié)點Java學(xué)院整理
這篇文章主要介紹了Javabean簡介,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-07-07Java日常練習(xí)題,每天進(jìn)步一點點(60)
下面小編就為大家?guī)硪黄狫ava基礎(chǔ)的幾道練習(xí)題(分享)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧,希望可以幫到你2021-08-08Java Spring Boot實現(xiàn)簡易掃碼登錄詳解
這篇文章主要為大家詳細(xì)介紹了java Spring Boot實現(xiàn)app掃碼登錄功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助2021-09-09