十年网站开发经验 + 多家企业客户 + 靠谱的建站团队
量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决
这篇文章给大家分享的是有关Python剪绳子的多种思路实现示例的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。
创新互联建站坚持“要么做到,要么别承诺”的工作理念,服务领域包括:网站设计、成都网站建设、企业官网、英文网站、手机端网站、网站推广等服务,满足客户于互联网时代的商南网站设计、移动媒体设计的需求,帮助企业找到有效的互联网解决方案。努力成为您成熟可靠的网络建设合作伙伴!题目:剪绳子
题:给你一根长度为n的绳子,请把绳子剪成m段(m,n都是整数,且n>1,m>1),每段绳子的长度记为k[0],k[1],k[2],...,k[m]。请问k[0]*k[1]*...*k[m]可能的大乘积是多少?例如,当绳子的长度为8时,我们把它剪成长度分别为2,3,3的三段,此时得到的大乘积为18。
解题思路一:基于动态规划和贪婪算法。
class Solution: def MaxProductAfterCut(self, n): # 动态规划 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))
解题思路二:基于动态规划和贪婪算法。
class Solution: # 动态规划 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)
Python主要应用于:1、Web开发;2、数据科学研究;3、网络爬虫;4、嵌入式应用开发;5、游戏开发;6、桌面应用开发。
感谢各位的阅读!关于“Python剪绳子的多种思路实现示例”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!
另外有需要云服务器可以了解下创新互联scvps.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。