AcWing 区间DP相关问题 1069. 凸多边形的划分

'''
区间DP
'''


N = int(input())
arr = list(map(int, input().split()))

from functools import lru_cache


# 序号i到j的节点序列的所有划分方案里面权值乘积之和的最小数值
@lru_cache(typed=False, maxsize=128000000)
def dp(i, j):
    if j == i + 2:
        return arr[i] * arr[i + 1] * arr[i + 2]
    else:
        # i-j连起来的这条边不动,枚举根这条边配对的点的位置,枚举切割位置
        ans = 0x7ffffffffffffffffffffffffffff
        for k in range(i + 1, j):
            if k == i + 1:
                ans = min(ans, arr[i] * arr[k] * arr[j] + dp(k, j))
            elif k == j - 1:
                ans = min(ans, arr[i] * arr[k] * arr[j] + dp(i, k))
            else:
                ans = min(ans, arr[i] * arr[k] * arr[j] + dp(i, k) + dp(k, j))
        return ans


print(dp(0, N - 1))

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值