剪绳子python_Python剪绳子如何实现 Python剪绳子实现代码
本篇文章小編給大家分享一下Python剪繩子實(shí)現(xiàn)代碼,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家供大家參考,有需要的小伙伴們可以來(lái)看看。
題目:剪繩子
給你一根長(zhǎng)度為n的繩子,請(qǐng)把繩子剪成m段(m,n都是整數(shù),且n>1,m>1),每段繩子的長(zhǎng)度記為k[0],k[1],k[2],...,k[m]。請(qǐng)問(wèn)k[0]*k[1]*...*k[m]可能的最大乘積是多少?例如,當(dāng)繩子的長(zhǎng)度為8時(shí),我們把它剪成長(zhǎng)度分別為2,3,3的三段,此時(shí)得到的最大乘積為18。
解題思路一:基于動(dòng)態(tài)規(guī)劃和貪婪算法。
class Solution:
def MaxProductAfterCut(self, n):
# 動(dòng)態(tài)規(guī)劃
if n<2:
return 0
if n==2:
return 1
if n==3:
return 2
products=[0]*(n+1)
products[0]=0
products[1]=1
products[2]=2
products[3]=3
for i in range(4,n+1):
max=0
for j in range(1,i//2+1):
product=products[j]*products[i-j]
if product>max:
max=product
products[i]=max
#print(products)
return products[n]
def MaxProductAfterCut2(self, n):
# 貪婪算法
if n < 2:
return 0
if n==2:
return 1
if n==3:
return 2
timesOf3 = n//3
if n - timesOf3*3 == 1:
timesOf3 -= 1
timesOf2 = (n - timesOf3 * 3)//2
return (3**timesOf3) * (2**timesOf2)
if __name__=="__main__":
print(Solution().MaxProductAfterCut(8))
print(Solution().MaxProductAfterCut(10))
#print(Solution().NumberOf1(0))
print(Solution().MaxProductAfterCut2(8))
print(Solution().MaxProductAfterCut2(10))
解題思路二:基于動(dòng)態(tài)規(guī)劃和貪婪算法。
class Solution:
# 動(dòng)態(tài)規(guī)劃
def maxCut(self, n):
if n<2: return 0
if n==2: return 1
if n==3: return 2
res=[0]*(n+1)
res[0], res[1], res[2], res[3]=0, 1, 2, 3
for i in range(4, n+1):
max = 0
for j in range(1, i//2+1):
temp = res[j]*res[i-j]
if temp>max:
max = temp
res[i]=max # 由下而上
return res[n]
# 貪婪算法
def cutRope(length):
if length<2: return 0
if length==2: return 1
if length==3: return 2
timesOf3 = length // 3 # 盡可能剪出3
if length-timesOf3*3 == 1: # 如果最后余1,則留一段4分成兩半
timesOf3 -= 1
timesOf2 = (length-timesOf3*3) // 2
return (3**timesOf3) * (2**timesOf2)
《新程序員》:云原生和全面數(shù)字化實(shí)踐50位技術(shù)專家共同創(chuàng)作,文字、視頻、音頻交互閱讀總結(jié)
以上是生活随笔為你收集整理的剪绳子python_Python剪绳子如何实现 Python剪绳子实现代码的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: 蓝牙地址的name为null_蓝牙, e
- 下一篇: python计算n的32次方_获得用户输