洛谷P2308 添加括号【区间DP+记录合并方案】【绿】

博客探讨了洛谷P2308题目,即如何在不改变元素位置的情况下,通过添括号使得中间和之和最小。文章介绍了问题背景、输入输出格式和样例,并提供了动态规划的解题思路,强调了在递归过程中记录分界点的重要性。代码实现部分展示了如何通过递归求解并构造正确的括号序列。
摘要由CSDN通过智能技术生成

Date:2022.03.25
题目背景
给定一个正整数序列a(1),a(2),…,a(n),(1<=n<=20)
不改变序列中每个元素在序列中的位置,把它们相加,并用括号记每次加法所得的和,称为中间和。
例如:
给出序列是4,1,2,3。
第一种添括号方法:
((4+1)+(2+3))=((5)+(5))=(10)
有三个中间和是5,5,10,它们之和为:5+5+10=20
第二种添括号方法
(4+((1+2)+3))=(4+((3)+3))=(4+(6))=(10)
中间和是3,6,10,它们之和为19。
题目描述
现在要添上n-1对括号,加法运算依括号顺序进行,得到n-1个中间和,求出使中间和之和最小的添括号方法。
输入格式
共两行。 第一行,为整数n。(1< =n< =20) 第二行,为a(1),a(2),…,a(n)这n个正整数,每个数字不超过100。
输出格式
输出3行。 第一行,为添加括号的方法。 第二行,为最终的中间和之和。 第三行,为n-1个中间和,按照从里到外,从左到右的顺序输出。
输入输出样例
输入 #1复制
4
4 1 2 3
输出 #1复制
(4+((1+2)+3))
19
3 6 10

思路:石子合并过程即为一个二叉树递归,其核心在于找到每一步的分界点,因此第一次区间dp求出最优解同时记录下这个区间的分界点。第三行要递归得出,但需要注意这个过程要保证深层的、先合并的先输出,因此体现在代码上是先递归再输出。第一行不会看了题解,发现也是递归,每次区间是 [ l , r ] [l,r] [l,r],因此向下递归即在 l l l左边加上 ′ ( ′ '(' ( r r r右边加上 ′ ) ′ ')' </

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值