343 整數拆分

2021-10-17 20:46:26 字數 830 閱讀 1620

343. 整數拆分

給定乙個正整數 n,將其拆分為至少兩個正整數的和,並使這些整數的乘積最大化。 返回你可以獲得的最大乘積。

示例 1:

輸入: 2

輸出: 1

解釋: 2 = 1 + 1, 1 × 1 = 1。

示例 2:

輸入: 10

輸出: 36

解釋: 10 = 3 + 3 + 4, 3 × 3 × 4 = 36。

基本思路:動態規劃,dp[i]表示的是數字i可以拆分的最大乘積,數字可以拆分為2,3個及其以上的數字相乘,f(i)=max((i-j)*j,j*dp[i-j]);其中dp[i-j]可以表示2個及以上的乘積

int integerbreak(int n) 

}return dp[n];

}

基本思路:令f(x)=x1*x2*……xk,其中 sum(x1~xk)=x,有算術平均不等式知,當x1=x2=x3……=xk時,f(x)取得最大值,故該問題轉換成已知x,求f(k)=(x/k)^(k)=(x/k)^(k/x*x)=(x/k)^((k/x)*x),其中,x是常數,令g(t)=t^(1/t),求導,當t=e時,取極值,對比發現,當xi=3時,f(x)最大,

int integerbreak(int n) 

int dp[3]=; //0+3,1+3,2+3;

return ans*dp[remainder];

}

343 整數拆分

題目鏈結 首先根據題目很容易的到的乙個點是 要使乘積最大能選擇的 數字只能是1 2 3 之後選擇的任何乙個數都可以拆分成這三個的乘積所以只要選這三個就可以。證明方法就是 假設輸入的數為x在x 4 的時候 2 x 2 x恆成立因此在選擇 乘積大於4的時候總是能選擇乙個 x 和 x 2 拆分這個資料 如...

343 整數拆分

給定乙個正整數 n,將其拆分為至少兩個正整數的和,並使這些整數的乘積最大化。返回你可以獲得的最大乘積。示例 1 輸入 2 輸出 1 解釋 2 1 1,1 1 1。示例 2 輸入 10 輸出 36 解釋 10 3 3 4,3 3 4 36。說明 你可以假設 n 不小於 2 且不大於 58。求最值問題最...

343 整數拆分

給定乙個正整數 n,將其拆分為至少兩個正整數的和,並使這些整數的乘積最大化。返回你可以獲得的最大乘積。令dp i 表示正整數i拆分時獲得的最大乘積,那麼i可以拆分為j和i j,如果i j不在拆分,乘積就是j i j 如果繼續拆分,乘積就是j dp i j 遍歷j取最大值即可。邊界條件,dp 0 dp...