1、題目:
給你一根長度為n的繩子,請把繩子剪成整數長的m段(m、n都是整數,n>1並且m>1),每段繩子的長度記為k[0],k[1],...,k[m]。請問k[0]xk[1]x...xk[m]可能的最大乘積是多少?例如,當繩子的長度是8時,我們把它剪成長度分別為2、3、3的三段,此時得到的最大乘積是18。
輸入乙個數n,意義見題面。(2 <= n <= 60)
輸出答案。2、分析:
設f(n)為把長度為n的繩子剪成若干段後各段長度乘積的最大值。在減第一刀的時候,有n-1種可能,也即減出來的第一段繩子的長度為1,2,......n-1,所以可知:f(n)=max(f(1)*f(n-1),f(2)*f(n-2),.....f(n-1)*f(1)),也即f(n)=max(f(i)*f(n-i)),03、**:
public class solution
if(target == 2)
if(target == 3)
int result = new int[target+1];
result[0] = 0;
result[1] = 1;
result[2] = 2;
result[3] = 3;
for(int i = 4; i <=target; i++)
result[i] = max;}}
return result[target];
}}
劍指Offer 剪繩子 和剪繩子
劍指offer 剪繩子 題目描述 給你一根長度為 n 的繩子,請把繩子剪成整數長度的 m 段 m n都是整數,n 1並且m 1 每段繩子的長度記為 k 0 k 1 k m 請問 k 0 k 1 k m 可能的最大乘積是多少?例如,當繩子的長度是8時,我們把它剪成長度分別為2 3 3的三段,此時得到的...
劍指offer 剪繩子
題目 給你一根長度為n繩子,請把繩子剪成m段 m n都是整數,n 1並且m 1 每段的繩子的長度記為k 0 k 1 k m k 0 k 1 k m 可能的最大乘積是多少?例如當繩子的長度是8時,我們把它剪成長度分別為2 3 3的三段,此 時得到最大的乘積18。思路 動態規劃 任何動態規劃都是由遞迴演...
《劍指Offer》剪繩子
給你一根長度為n的繩子,請把繩子剪成m段 m n都是整數,n 1並且m 1 每段繩子的長度記為k 0 k 1 k m 請問k 0 xk 1 x.xk m 可能的最大乘積是多少?例如,當繩子的長度是8時,我們把它剪成長度分別為2 3 3的三段,此時得到的最大乘積是18 乘法計算,除了一以外,越多的數相...