亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

劍指offer 14.剪繩子 Python解法

系統 2022 0

題目描述:

給你一根長度為 n 繩子,請把繩子剪成 m 段(m、n 都是整數,2≤n≤58 并且 m≥2)。 每段的繩子的長度記為k[0]、k[1]、……、k[m]。k[0]k[1] … k[m] 可能的最大乘積是多少?

例如:當繩子的長度是8時,我們把它剪成長度分別為2、3、3的三段,此時得到最大的乘積18。

分析:

書上說的有數學規律:(看注釋)

            
              # 方法一:貪婪算法
def maxProductAfterCutting(length):
    if length == 2:                   # 這3個特殊的長度,直接求出返回值
        return 1
    elif length == 3:
        return 2
    elif length == 4:
        return 4
    c=[]
    while length >= 5:               # 由數學計算得出,當長度大于5時候,每段長3,乘積最大
        length-=3                    # 巧的是,如果最后剩4,分成2*2 乘積最大,但是4正好是2*2的值。巧!
        c.append(3)
    return 3**len(c)*length

maxProductAfterCutting(6)
            
          

方法二:動態規劃。把前邊的都求出來。

(從此題首次接觸動態規劃。)

            
              # 方法二:動態規劃
def dynamic_programming(n):
    if n==2:                         # 這3個特殊的長度,直接求出返回值
        return 1
    if n==3:
        return 2
    if n==4:
        return 4
    tem_lis = [0,0,2,3,4]                 # 這個列表的前兩個數無所謂,因為根本用不到
    
    for i in range(5,n+1):                # 外循環:繩子長度從5到n  注意range()前閉后開。
        maxx = 0 
        for j in range(2,i//2+1):         # 內循環:所有可能的組合:2,3,4...中間值
            tem = tem_lis[j]*tem_lis[i-j] # i-j 為另一段長度
            if tem > maxx:
                maxx = tem                # maxx存放乘積最大的值
        tem_lis.append(maxx)              # tem_list中存儲的是所有的可能繩子長度的解
    #print(tem_lis)
    return tem_lis[n]

dynamic_programming(8)
                
            
          

?


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 青青青青爽视频在线播放 | 伊人成人在线观看 | 天天插天天干天天射 | 久久精品国产一区 | 久久草在线视频观看 | 成人午夜视频免费看欧美 | 久久这里只有精品视频99 | 在线性视频 | 99免费看| 女人一级毛片 | 天天摸日日碰天天看免费 | 96精品专区国产在线观看高清 | 6080欧美一区二区三区四区 | 乱子伦xxx欧美 | 九九在线精品视频播放 | 中文字幕日韩精品在线 | 福利视频不卡 | 91精品国产综合久久久久久 | 福利午夜最新 | 综合欧美日韩 | 亚洲精品久久一区二区无卡 | 日日摸夜夜添夜夜添人人爽 | 91视频国产91久久久 | 高清视频 一区二区三区四区 | 成人性色生活片免费网 | 亚洲成在人线影视天堂网 | 亚洲一二三区在线观看 | 一区二区三区中文 | 久久国产免费一区二区三区 | 夜夜操综合 | 日韩精品亚洲一级在线观看 | 日韩精品福利视频一区二区三区 | 真实偷拍激情啪啪对白 | 日本久操视频 | 九九资源网 | 91aaa免费观看在线观看资源 | 动漫三级在线观看 | 久久精品视频一区 | 一级片视频网站 | 激情在线视频 | 成人精品一区二区久久久 |