题目描述:
给你一根长度为 n 的绳子,请把绳子剪成整数长的 m 段( m 、 n 都是整数, n > 1 并且 m > 1 , m <= n ),每段绳子的长度记为 k[1],…,k[m] 。请问 k[1]k[2]…*k[m] 可能的最大乘积是多少?例如,当绳子的长度是 8 时,我们把它剪成长度分别为 2、3、3 的三段,此时得到的最大乘积是 18 。
解题思路:
动态规划的方法:
先自上而下分析,在长度为n的绳子所求为f(n),剪下一刀后剩下的两段长度是i和n-i,在这个上面还可能继续减(子问题),所以:
f(n)=f(i)*f(n-i) , i∈[1,n)
然后自下而上的解决问题,可以从f(1)开始向上计算并保存,最终获得f(n)的值。
由于当i大于n//2时,就不用在计算了,重复计算。因此:
i∈[1,n//2]
python代码实现:
class Solution:
def cutRope(self , number: int) -> int:
# write code here
if number<2:
return 0
if number==2:
return 1
if number==3:
return 2
products=[0,1,2,3]
for i in range(4,number+1):
product=0
for j in range(1,i//2+1):
res=products[j]*products[i-j]
product=max(res, product)
products.append(product)
return products[number]