P2308 添加括号
P2308 添加括号
题解
一看这题---我能AC
看完这题---我要换题
这题第二问其实就是一个链的石子合并,也就是不用处理环
所以一三问怎么处理???
数组 mid[ i ][ j ] 记录区间 [ l , r ] 的断点
数组 le[ i ] 表示 a[i] 左边有几个左括号
数组 ri[ i ] 表示 a[i] 右边有几个右括号
递归处理一下括号数

单数字两边肯定不能有括号
我们在区间左右各标记上左右括号之后,继续向下递归,分别处理断开的两段区间
递归处理括号数

先输出数字周围的括号,再输出这个数字,注意每两个数字之间都是要有+连接的
然后输出最小合并
递归输出中间合并部分结果

合并左半部分的值,合并右半部分的值,两个部分一起合并的值
注意

(=的时候也是要更新一下mid的,可能是为了不断动态更新我编不动了)
代码
#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cmath>
#include<string>
#include<cstring>
#include<cstdlib>
#include<queue> using namespace std; typedef long long ll; inline int read()
{
int ans=;
char last=' ',ch=getchar();
while(ch<''||ch>'') last=ch,ch=getchar();
while(ch>=''&&ch<='') ans=ans*+ch-'',ch=getchar();
if(last=='-') ans=-ans;
return ans;
} int n,a[],sum[];
int f[][],mid[][];
int le[],ri[]; void cnt(int l,int r)
{
if(l==r) return ;
le[l]++;
ri[r]++;
cnt(l,mid[l][r]);
cnt(mid[l][r]+,r);
} void print(int l,int r)
{
if(l==r) return;
print(l,mid[l][r]);
print(mid[l][r]+,r);
printf("%d ",sum[r]-sum[l-]);
} int main()
{
n=read();
memset(f,0x7f,sizeof(f));
for(int i=;i<=n;i++) a[i]=read(),sum[i]=sum[i-]+a[i],f[i][i]=; for(int l=;l<=n;l++)
for(int i=;i+l-<=n;i++){
int j=i+l-;
for(int k=i;k<j;k++){
if(f[i][k]+f[k+][j]<=f[i][j]){
f[i][j]=f[i][k]+f[k+][j];
mid[i][j]=k;
}
}
f[i][j]+=sum[j]-sum[i-];
} cnt(,n);
for(int i=;i<=n;i++){
for(int j=;j<=le[i];j++) printf("(");
printf("%d",a[i]);
for(int j=;j<=ri[i];j++) printf(")");
if(i!=n) printf("+");
}
printf("\n%d\n",f[][n]);
print(,n); return ;
}
P2308 添加括号的更多相关文章
- P2308 添加括号(区间DP)
题目背景 给定一个正整数序列a(1),a(2),...,a(n),(1<=n<=20) 不改变序列中每个元素在序列中的位置,把它们相加,并用括号记每次加法所得的和,称为中间和. 例如: 给 ...
- P2308 添加括号(dfs记录dp路径)
传送门 \(一看肯定是区间DP(因为和和合并石子很相似,都要加n-1次)\) \(转移方程为(其中he[i][j]是i到j的和)\) \[dp[i][j]=min(dp[i][j],dp[i][k]+ ...
- [LeetCode] Different Ways to Add Parentheses 添加括号的不同方式
Given a string of numbers and operators, return all possible results from computing all the differen ...
- vijosP1038 添加括号
vijosP1038 添加括号 链接:https://vijos.org/p/1038 [思路] 区间DP. 本题的关键在于如何输出解.对于求和表达式而言可以用一个p[][]记录决策然后递归输出,对于 ...
- P2651 添加括号III
P2651 添加括号III无论怎么添加,a2一定是分母,其他的可以是分子,所以最后看看,(a1*a3*..*an)%a2==0即可 #include<iostream> #include& ...
- luogu 2308添加括号
添加括号 传送门 题目大意 现在要添上n-1对括号,加法运算依括号顺序进行,得到n-1个中间和,求出使中间和之和最小的添括号方法. 这道题其实是一个很简单的区间dp,中间和的意思是括号里面的和,也就是 ...
- [LeetCode] 241. Different Ways to Add Parentheses 添加括号的不同方式
Given a string of numbers and operators, return all possible results from computing all the differen ...
- ci框架 用框架自带db 添加括号,比如 like 等等左右添加括号 解决办法
$this->load->model('station/Station_model','Station'); // East // North $this->Station-> ...
- 动态规划dp专题练习
貌似开坑还挺好玩的...开一个来玩玩=v=... 正好自己dp不是很熟悉,就开个坑来练练吧...先练个50题?小目标... 好像有点多啊QAQ 既然是开坑,之前写的都不要了! 50/50 1.洛谷P3 ...
随机推荐
- 使用CDS view开发SAP Marketing contact的facet追溯工具
这篇SAP社区博客里,我的一位同事介绍了SAP Marketing里contact facet数据模型的存储表: https://blogs.sap.com/2016/07/01/how-does-s ...
- VMware Workstation中虚拟机与windows10共享文件夹
设置共享文件夹之前需要确定已经安装VMware Tools 1.在windows桌面新建一个名为share_folder的文件夹用来共享 2.右键点击虚拟机的名字,在弹出的菜单中选择设置 弹出对话框 ...
- 二〇一八-网易秋招面试解析(Java)
一轮面试: Java内存模型讲一下 GC算法,知道的都讲一下 HashMap,get,put实现 JsonWebToken具体实现流程(简历) Spring AOP如何实现,写一个AOP功能的主要流程 ...
- 第三章、drf-ModelSerializer
目录 ModelSerializer ModelSerializer 序列化 使用: ModelSerializer 反序列化 使用: ModelSerializer 序列化反序列化整合(*****) ...
- zookeeper:2
单机环境下安装: 下载地址:http://apache.fayea.com/zookeeper/stable/ 解压zookeeper :tar -zxvf zookeeper-3.4.10.tar. ...
- Python(phone)模块获取手机号归属地、区号、运营商等
Python(phone)模块获取手机号归属地.区号.运营商等 一.我使用的是python3,可以自行搜索下载 二.安装phone模块, pip install phone 三.测试代码如下: fro ...
- django 搜索引擎 Elasticsearch 安装使用
1.使用docker安装elasticsearch a.获取镜像 # 拉取镜像到本地仓库 # docker image pull delron/elasticsearch-ik:2.4.6-1.0 由 ...
- (14)占位符%和format
# 在介绍占位符之前,这里先介绍下索引,索引可以方便的帮我们拿到容器内的数据 # 索引可以简单的理解为一个有序的标记,我们把容器里的元素每一个都编上一个编号 # 凡是有序的容器类型数据,都可以通过索引 ...
- 虚拟机配置双网卡适配器后(桥接和NAT模式),重新打开后两个适配器的ip都没有了(重启网卡报Job for network.service failed because the control process exited with error code)
科普双网卡适配器的好处: 我是配了一个桥接模式的网卡和一个NAT模式的网卡,桥接模式,也就是将虚拟机的虚拟网络适配器与主机的物理网络适配器进行交接,虚拟机中的虚拟网络适配器可通过主机中的物理网络适配器 ...
- 线程的 run()和 start()有什么区别?(未完成)
线程的 run()和 start()有什么区别?(未完成)