[区间dp]添加括号
题目描述
有一个 n n n 个元素的数组 a a a。不改变序列中每个元素在序列中的位置,把它们相加,并用括号记每次加法所得的和,称为中间和。现在要添上 n − 1 n - 1 n−1 对括号,加法运算依括号顺序进行,得到 n − 1 n - 1 n−1 个中间和,求出使中间和之和最小的添括号方法。
例如:给出序列是 4 , 1 , 2 , 3 4,1,2,3 4,1,2,3 。
第一种添括号方法:
( ( 4 + 1 ) + ( 2 + 3 ) ) = ( ( 5 ) + ( 5 ) ) = ( 10 ) ((4 + 1) + (2 +3)) = ((5) + (5)) = (10) ((4+1)+(2+3))=((5)+(5))=(10)。
有三个中间和是 5 , 5 , 10 5,5,10 5,5,10 ,它们之和为: 5 + 5 + 10 = 20 5 + 5 + 10 = 20 5+5+10=20。
第二种添括号方法:
( 4 + ( ( 1 + 2 ) + 3 ) ) = ( 4 + ( ( 3 ) + 3 ) ) = ( 4 + ( 6 ) ) = ( 10 ) (4 + ((1 + 2) + 3)) = (4 + ((3) + 3)) = (4 + (6)) = (10) (4+((1+2)+3))=(4+((3)+3))=(4+(6))=(10)。
有三个中间和是 3 , 6 , 10 3,6,10 3,6,10 ,它们之和为 3 + 6 + 10 = 19 3 + 6 + 10 = 19 3+6+10=19 。
输入格式
第一行输入一个整数 n n n,表示 a a a 元素个数。
第二行输入 n n n 个整数 a i a_i ai。
输出格式
第一行输出添加括号的方法。
第二行输出最终的中间和之和。
第三行输出 n − 1 n - 1 n−1 个中间和,按照从里到外,从左到右的顺序输出。
样例
样例输入1:
4
4 1 2 3
样例输出1:
(4+((1+2)+3))
19
3 6 10
样例解释见上。
数据范围
1 ≤ n ≤ 20 1 \le n \le 20 1≤n≤20
1 ≤ a i ≤ 100 1 \le a_i \le 100 1≤ai≤100
题解
将 + + + 看成合并左右两个元素, ( ) () () 限定合并顺序。
按照正常的 区间dp ,很容易计算出中间和之和。
那如何输出算式和每个中间和呢?
当把区间 i , k i, k i,k 和 k + 1 , j k + 1, j k+1,j 合并成 i , j i, j i,j 时,记录 k − i k - i k−i 的值(合并位置 d i , j d_{i, j} di,j)。
然后写一个 dfs,传两个参数 l l l 和 r r r,表示 l l l 到 r r r 的区间。
- 如果 l ≥ r l \ge r l≥r,返回。
- 如果 l < r l < r l<r,将 l l l 到 r r r 的区间拆分为两个区间进行
dfs( l l l 到 l + d i , j l + d_{i, j} l+di,j, l + d i , j + 1 l + d_{i, j} + 1 l+di,j+1 到 r r r),并将 l l l 的左括号数( f 1 l f1_l f1l)加 1 1 1, r r r 的右括号数( f 2 r f2_r f2r)加 1 1 1。
接下来从 1 1 1 到 n n n 输出,先输出 f 1 i f1_i f1i 个左括号,再输出 a i a_i ai,然后输出 f 2 i f2_i f2i 个右括号。如果 i ≠ n i \ne n i=n,还要输出 + + +。
这样就能轻松地输出算式了。
输出中间和也是同理,可用前缀和优化。
int f[40][40];//dp
int sum[40];//前缀和
int d[40][40];//从 i 到 j 合并的点
int f1[40], f2[40];//左括号数和右括号数
//算式
void dfs(int x, int y){if(x >= y){return;}dfs(x, x + d[x][y]);dfs(x + d[x][y] + 1, y);f1[x] ++;f2[y] ++;
}
//中间和
void dfs2(int x, int y){if(x >= y){return;}dfs2(x, x + d[x][y]);dfs2(x + d[x][y] + 1, y);printf("%d ", sum[y] - sum[x - 1]);
}
int main(){输入//初始化memset(f, 0x3f, sizeof(f)));memset(d, 0, sizeof(d));for(int i = 1; i <= n; ++ i){f[i][i] = 0;}//前缀和for(int i = 1; i <= n; ++ i){sum[i] = sum[i - 1] + a[i];}for(int k = 1; k < n; ++ k){for(int i = 1; i <= n - k; ++ i){int j = i + k;for(int u = i; u < j; ++ u){//更新 f[i][j]if(f[i][j] > f[i][u] + f[u + 1][j]){f[i][j] = f[i][u] + f[u + 1][j];d[i][j] = u - i;}}f[i][j] += sum[j] - sum[i - 1];}}//输出 dfs(1, n); for(int i = 1; i <= n; ++ i){while(f1[i]){putchar('(');f1[i] --;}printf("%d", a[i]);while(f2[i]){putchar(')');f2[i] --;}if(i != n){putchar('+');}}printf("\n%d\n", f[1][n]);dfs2(1, n);return 0;
}
禁止抄袭!!!
相关文章:
[区间dp]添加括号
题目描述 有一个 n n n 个元素的数组 a a a。不改变序列中每个元素在序列中的位置,把它们相加,并用括号记每次加法所得的和,称为中间和。现在要添上 n − 1 n - 1 n−1 对括号,加法运算依括号顺序进行,得到 n − …...
jenkins流水线+k8s部署springcloud微服务架构项目
文章目录 1.k8s安装2.jenkins安装3.k8s重要知识1.简介2.核心概念3.重要命令1.查看集群消息2.命名空间3.资源创建/更新4.资源查看5.描述某个资源的详细信息6.资源编辑7.资源删除8.资源重启9.查看资源日志10.资源标签 4.k8s控制台1.登录2.界面基本操作1.选择命名空间2.查看命名空…...
安卓开发板_联发科MTK开发评估套件串口调试
串口调试 如果正在进行lk(little kernel ) 或内核开发,USB 串口适配器( USB 转串口 TTL 适配器的简称)对于检查系统启动日志非常有用,特别是在没有图形桌面显示的情况下。 1.选购适配器 常用的许多 USB 转串口的适配器…...
vue+el-table 可输入表格使用上下键进行input框切换
使用上下键进行完工数量这一列的切换 <el-table :data"form.detailList" selection-change"handleChildSelection" ref"bChangeOrderChild" max-height"500"><!-- <el-table-column type"selection" width&quo…...
中国书法——孙溟㠭浅析碑帖《三希堂法帖》
孙溟㠭浅析碑帖《三希堂法帖》 全称是《三希堂石渠宝笈法帖》,是中国清代宫廷刻帖,一共三十二册。 清朝高宗弘历收藏了晋王羲之《快雪时晴帖》,王献之的《中秋帖》,王珣的《伯远帖》三种王氏原墨迹。故而把所藏法书之所…...
深入探讨生成对抗网络(GANs):颠覆传统的AI创作方式
在人工智能的快速发展中,生成对抗网络(Generative Adversarial Networks, GANs)无疑是一个引人注目的技术。自2014年由Ian Goodfellow等人首次提出以来,GANs已经在图像生成、文本生成、视频生成等多个领域展现出了惊人的能力。本文…...
vmware Vnet8虚拟网卡丢失的找回问题
vmware Vnet8虚拟网卡丢失的找回问题 1.打开VMware Workstation 2.然后点击Edit --> Virtual Network Edit --> 打开Virtual Network Edit框 , 3.点击最下面的的Restore Default 按钮, 3.恢复默认设置,这会在网络连接那块可以看到丢失…...
Python 从入门到实战13(字符串简介)
我们的目标是:通过这一套资料学习下来,通过熟练掌握python基础,然后结合经典实例、实践相结合,使我们完全掌握python,并做到独立完成项目开发的能力。 上篇文章我们通过举例学习了流程控制语句中的循环语句。今天继续讨…...
Redis_RDB持久化
基于RDB的持久化方式会把当前内存中所有的redis键值对数据以快照的方式写入硬盘文件中,如果需要恢复数据,就把快照文件读到内存中。 RDB快照文件是经压缩的二进制格式的文件,它的储存路径不仅可以在redis服务器启动前通过配置参数来设置&…...
SOP流程制定:vioovi ECRS工时分析软件的智慧引领
在现代制造业中,标准化操作流程(SOP)已成为提升生产效率、确保产品质量、降低运营成本的关键要素。SOP不仅为生产活动提供了明确的指导,还促进了企业管理的规范化和精细化。然而,如何科学、高效地制定SOP流程ÿ…...
并发编程-synchronized解决原子性问题
并发编程-synchronized解决原子性问题 文章目录 并发编程-synchronized解决原子性问题零、说在前面一、线程安全问题1.1 什么是线程安全问题1.2 自增运算不是线程安全的1.3 临界区资源与临界区代码段 二、synchronized 关键字的使用2.1 synchronized 关键字作用2.2 synchronize…...
CSS之我不会
非常推荐html-css学习视频:尚硅谷html-css 一、选择器 作用:选择页面上的某一个后者某一类元素 基本选择器 1.标签选择器 格式:标签{} <h1>666</h1><style>h1{css语法} </style>2.类选择器 格式:.类…...
AI绘画:SD打光神器!(Stable Diffusion进阶篇:Imposing Consistent Light)
前言 在上一篇笔记中学习了如何简单地下载以及使用IC-Light,今天的内容会稍微有点不一样。 对于学过stable diffusion的小伙伴来说,forge UI和Comfy UI会更加熟悉一些。在IC-Light发布后,Openpose editor的开发者将其制作成了一个Forge UI上…...
QQ频道机器人零基础开发详解(基于QQ官方机器人文档)[第二期]
QQ频道机器人零基础开发详解(基于QQ官方机器人文档)[第二期] 第二期介绍:频道模块之频道管理 目录 QQ频道机器人零基础开发详解(基于QQ官方机器人文档)[第二期]第二期介绍:频道模块之频道管理获取用户详情获取用户频道列表获取频道详情获取子频道列表获…...
参赛心得和思路分享:2021第二届云原生编程挑战赛2: 实现一个柔性集群调度机制
关联比赛: 2021第二届云原生编程挑战赛2:实现一个柔性集群调度机制 参赛心得 历时快两个月的第二届云原生编程挑战赛结束了,作为第一次参赛的萌新,拿下了28名的成绩,与第一名差了19万分,因为赛制时间太长,…...
具体函数的卡诺图填入
目录 用卡诺图表示逻辑函数 基本步骤 例子1 例子2 例子3 用卡诺图表示逻辑函数 基本步骤 例子1 由真值表得卡诺图。 在函数值为1的地方在卡诺图上画上1。 例子2 例子3 非标准与或式,要找到公共部分。 将AB所在的那一行填上1。 将A非D的那个部分也填上1。 再…...
STM32 HAL freertos零基础(六)计数型信号量
1、计数型信号量 计数型信号量(Counting Semaphore)是另一种类型的信号量,它可以保持一个大于等于0的整数值,这个值表示可用资源的数量。本质上相当于队列长度大于1得队列。经典问题就是剩余车辆统计,出入车辆,车辆数据可以实时更新。 2、相关API函数 xSemaphoreCreat…...
Dynamics CRM Ribbon Workbench-the solution contains non-entity components
今天在一个低版本的环境里准备用Ribbon Workbench去编辑一个按钮时,遇到了如下错误 一开始没当回事,以为是我的解决方案问题,去检查了下,只有一个组件,并且哪怕我把组件换成了某个实体也不行,尝试了其他任何…...
谷歌对抗司法部:为什么谷歌的“数百个竞争对手”说法站不住脚
随着谷歌反垄断陪审团审判的进行,谷歌声称美国司法部对广告技术市场的看法狭隘,并且广告商和出版商有很多替代选择。然而,证据并不支持这一说法。 谷歌误导性地声称有“数百个竞争对手。” 虽然存在许多广告技术提供商,但谷歌在…...
重生奇迹MU 沉迷升级的快感 法魔升级机器人
重生奇迹MU是一款以升级为主要玩法的游戏。升级是游戏基础,也是最重要的部分。通过升级,玩家可以获得更多的基础属性奖励和自由点数奖励,同时还能够穿戴最好的装备和翅膀。因此,升级在游戏中具有极其重要的地位。 史上升级最快的…...
C++ `const_cast`
1. C 类型转换基础 C为何需要类型转换C风格类型转换与C风格类型转换类型转换的种类:static_cast, dynamic_cast, const_cast, reinterpret_cast 2. const 限定符基础 为何需要 const 限定符const 的位置和含义 对象为 const指针为 const指针指向的内容为 const3. co…...
如何用btcrecover快速找回丢失的比特币钱包密码与助记词:完整指南
如何用btcrecover快速找回丢失的比特币钱包密码与助记词:完整指南 【免费下载链接】btcrecover An open source Bitcoin wallet password and seed recovery tool designed for the case where you already know most of your password/seed, but need assistance i…...
2026局放仪选型与避坑:谁家局放仪更具性价比?
在高压配电网与智能电网的运维体系中,局部放电(Partial Discharge, PD)检测已成为保障电力资产安全、避免非计划停电的关键环节。根据《高压开关柜局部放电诊断定位技术研究与运用》的统计数据,在开关柜的各类故障中,绝…...
Aspia代码架构解析:从基础库到完整应用的开发思路
Aspia代码架构解析:从基础库到完整应用的开发思路 【免费下载链接】aspia Remote desktop and file transfer tool. 项目地址: https://gitcode.com/gh_mirrors/as/aspia Aspia是一款功能强大的开源远程桌面和文件传输工具,支持Windows、Linux和m…...
直线模组选型别再“先选电机“了!导程才是起点(附正向推导五步法)
引言:一个高频"翻车"现场在直线模组(丝杆模组)选型中,有个环节经常出现逆向翻车——工程师先选好了电机,再去配丝杆导程,结果发现:❌ 速度上不去❌ 推力不够大❌ 电机严重发热问题的根…...
【实测可用 v 2.7.5】Open Claw 本地环境快速部署搭建攻略
✨ 核心亮点 零代码门槛|全程可视化|无需手动配环境|内置所有依赖 🔗 下载地址 https://xiake.yun/api/download/package/16?promoCodeIV8E496E2F7A 📝 前言 2026 年开源圈热门的「数字员工」OpenClaw(…...
人工智能学习之归一化和标准化的区别
归一化与标准化(机器学习核心预处理笔记) 核心前提:机器学习中,特征的量纲(单位)可能差异极大(如:身高cm、体重kg、收入万元),会导致模型(如KNN、…...
手把手教你用STM32F103C8T6和NTC热敏电阻DIY一个水温监测器(附完整代码)
手把手教你用STM32F103C8T6和NTC热敏电阻DIY一个水温监测器(附完整代码) 水温监测在家庭养鱼、咖啡机控制、热水器管理等场景中非常实用。本文将带你从零开始,用最常见的STM32F103C8T6最小系统板和NTC热敏电阻,打造一个低成本、高…...
ADF4350频点锁定与电源滤波实战:为什么你的VCO输出有噪声?加个钽电容试试!
ADF4350频点锁定与电源滤波实战:为什么你的VCO输出有噪声?加个钽电容试试! 在射频电路设计中,ADF4350作为一款集成VCO的宽带频率合成器,因其出色的性能和灵活性广受工程师青睐。然而,许多开发者在实际应用中…...
不止于仿真:用MATLAB分析OFDM-QPSK系统抗噪声性能,这张误码率曲线图能告诉你什么?
从误码率曲线到系统优化:MATLAB深度解析OFDM-QPSK抗噪性能 在无线通信系统的设计与评估中,仿真分析是不可或缺的一环。当我们完成基础OFDM-QPSK系统的搭建后,如何从仿真结果中提取有价值的信息,进而指导系统优化?本文…...
