日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

343. 整数拆分 golang 动态规划

發(fā)布時間:2023/11/30 编程问答 26 豆豆
生活随笔 收集整理的這篇文章主要介紹了 343. 整数拆分 golang 动态规划 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

題目

  • 整數(shù)拆分
    給定一個正整數(shù) n,將其拆分為至少兩個正整數(shù)的和,并使這些整數(shù)的乘積最大化。 返回你可以獲得的最大乘積。
  • 示例 1:

    輸入: 2
    輸出: 1
    解釋: 2 = 1 + 1, 1 × 1 = 1。
    示例 2:

    輸入: 10
    輸出: 36
    解釋: 10 = 3 + 3 + 4, 3 × 3 × 4 = 36。
    說明: 你可以假設(shè) n 不小于 2 且不大于 58。

    解法

    首先這個題可以不用動態(tài)規(guī)劃的方式做出來。思路是將任何一個數(shù)拆分成多少個3,然后進行余數(shù)判斷,就可以得到正確答案。

    動態(tài)規(guī)劃

    code

    func integerBreak(n int) int {dp := make([]int, n+1)dp[1] = 1dp[2] = 1for i := 3; i <=n; i++ {for j := 1; j < i; j++ {dp[i] = max(dp[i], j * max(i-j, dp[i-j]))}}// fmt.Println(dp)return dp[n] }func max(a, b int) int {if a > b {return a}return b }

    總結(jié)

    以上是生活随笔為你收集整理的343. 整数拆分 golang 动态规划的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。