中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Java怎么解決打家劫舍的問題

發布時間:2021-12-20 15:42:54 來源:億速云 閱讀:148 作者:iii 欄目:大數據

本篇內容主要講解“Java怎么解決打家劫舍的問題”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“Java怎么解決打家劫舍的問題”吧!

  Java怎么解決打家劫舍的問題

如果要打劫第n家,就必然不能打劫第n-1家,所以打劫第n家得到的錢一共是第n家的錢加上前n-2家獲得的最多的錢,即:f(n-2)+nums(n),如果不打劫第n家,獲得的最大收益就是f(n-1),兩者我們要去較大的那個,所以動態轉移方程是:

f(n)=max(nums[n]+f(n-2),f(n-1))

package mainimport "fmt"func max(a,b int)int{    if a>b {        return a    }    return b}func rob(nums []int) int {    if len(nums)==0 {        return 0    }    if len(nums)==1 {        return nums[0]    }     dp := make([]int,len(nums))     dp[0] = nums[0]     dp[1] = max(nums[0],nums[1])     maxVal := dp[1]     for i:=2;i<len(nums);i++{        dp[i] = max(dp[i-1],dp[i-2]+nums[i])        maxVal = max(maxVal,dp[i])     }     return maxVal}func main() {    fmt.Println(rob([]int{1,2,3,1}))    fmt.Println(rob([]int{2,7,9,3,1}))}

到此,相信大家對“Java怎么解決打家劫舍的問題”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

烟台市| 全南县| 墨脱县| 通许县| 屯留县| 杭锦旗| 黄浦区| 武邑县| 馆陶县| 且末县| 皮山县| 宁南县| 富阳市| 科技| 大关县| 原阳县| 永吉县| 尉犁县| 望城县| 阿尔山市| 龙川县| 定日县| 苏尼特左旗| 武鸣县| 华坪县| 丹凤县| 庄河市| 桓台县| 漯河市| 长泰县| 汶上县| 宁国市| 开平市| 揭西县| 石狮市| 南汇区| 常州市| 洛浦县| 甘孜县| 景德镇市| 焦作市|