【专题】区间dp
1.【nyoj737】石子合并
传送门:点击打开链接
描述 有N堆石子排成一排,每堆石子有一定的数量。现要将N堆石子并成为一堆。合并的过程只能每次将相邻的两堆石子堆成一堆,每次合并花费的代价为这两堆石子的和,经过N-1次合并后成为一堆。求出总的代价最小值。
- 输入
- 有多组测试数据,输入到文件结束。
每组测试数据第一行有一个整数n,表示有n堆石子。
接下来的一行有n(0< n <200)个数,分别表示这n堆石子的数目,用空格隔开 - 输出
- 输出总代价的最小值,占单独的一行
- 样例输入
-
3
1 2 3
7
13 7 8 16 21 4 18 - 样例输出
-
9
239 - 思路:
dp[i][j]=min(dp[i][j],dp[i][k]+dp[k+1][j]+sum[i][j]),dp[i][j]代表从i到j合并的最小值,sum[i][j]代表从i到j的价值和。
区间dp的循环是从小区间到大区间,根据这一规律写出循环结构。
注意dp[i][i]是0。
代码:
#include<bits/stdc++.h>
using namespace std;
int dp[][],a[],sum[][];
int main()
{
int n,i,j,k;
while(cin>>n)
{
memset(sum,,sizeof(sum));
memset(dp,0x3f3f3f3f,sizeof(dp));
for(i=; i<=n; i++)
{
scanf("%d",&a[i]);
dp[i][i]=;
sum[i][i]=a[i];
}
for(i=; i<n; i++)
{
for(j=i+; j<=n; j++)
sum[i][j]+=sum[i][j-]+a[j];
}
for(int len=; len<=n; len++)
for(i=; i<=n-len+; i++)
{
j=i+len-;
for(k=i; k+<=j; k++)
dp[i][j]=min(dp[i][j],dp[i][k]+dp[k+][j]+sum[i][j]);
}
printf("%d\n",dp[][n]);
}
return ;
}
2.【nyoj37】回文字符串
传送门:点击打开链接
给你一个字符串,可在任意位置添加字符,最少再添加几个字符,可以使这个字符串成为回文字符串。
样例输入
1
Ab3bd
样例输出
2
思路1:
利用反串找LCA
#include<bits/stdc++.h>
using namespace std;
char s[];
int dp[][];
int main()
{
int t,i,j;
cin>>t;
while(t--)
{
scanf("%s",s);
int n=strlen(s);
memset(dp,0x3f3f3f3f,sizeof(dp));
dp[][]=;
for(i=; i<n; i++)
dp[i][i]=dp[i][i-]=;
for(int len=; len<=n; len++)
for(i=; i<=n-len; i++)
{
j=i+len-;
if(s[i]==s[j]) dp[i][j]=dp[i+][j-];
else dp[i][j]=min(dp[i+][j]+,dp[i][j-]+);
}
printf("%d\n",dp[][n-]);
}
}
思路2:
s[i]=s[j],dp[i][j]=dp[i+1][j-1];若!=,dp[i][j]=min(dp[i+1][j]+1,dp[i][j-1]+1)
解释一下,假如回文串是「1123」,dp[1][4] = min(dp[1][3],dp[2][4]) + 1,先把「112」看成一个整体,dp[1][3] = 1,就是说再补一个就可以回文,最后加上一个「3」,也就是 +1 操作;「123」同理。
注意dp[i][i]=0,当len=2时,若s[i]=s[j]则dp[i][j]=0,所以初始化dp[i][i-1]也要全部赋为0
#include<bits/stdc++.h>
using namespace std;
char s[];
int dp[][];
int main()
{
int t,i,j;
cin>>t;
while(t--)
{
scanf("%s",s);
int n=strlen(s);
memset(dp,0x3f3f3f3f,sizeof(dp));
dp[][]=;
for(i=; i<n; i++)
dp[i][i]=dp[i][i-]=;
for(int len=; len<=n; len++)
for(i=; i<=n-len; i++)
{
j=i+len-;
if(s[i]==s[j]) dp[i][j]=dp[i+][j-];
else dp[i][j]=min(dp[i+][j]+,dp[i][j-]+);
}
printf("%d\n",dp[][n-]);
}
}
3.【nyoj15】括号匹配(二)
传送门:点击打开链接
描述给你一个字符串,里面只包含"(",")","[","]"四种符号,请问你需要至少添加多少个括号才能使这些括号匹配起来。
如:
[]是匹配的
([])[]是匹配的
((]是不匹配的
([)]是不匹配的
- 输入
- 第一行输入一个正整数N,表示测试数据组数(N<=10)
每组测试数据都只有一行,是一个字符串S,S中只包含以上所说的四种字符,S的长度不超过100 - 输出
- 对于每组测试数据都输出一个正整数,表示最少需要添加的括号的数量。每组测试输出占一行
- 样例输入
-
4
[]
([])[]
((]
([)] - 样例输出
-
0
0
3
2 - 思路:
- dp[i][j]=min(dp[i][j],dp[i][k]+dp[k+1][j]),特殊情况当s[i]与s[j]匹配时,dp[i][j]=min(dp[i][j],dp[i+1][j-1])
- 注意当截取长度为2且s[i]与s[j]匹配时,不需要添加符号,所以初始化dp[i][i-1]=0,dp[i][i]=1。
#include<bits/stdc++.h>
using namespace std;
char s[];
int dp[][];
int main()
{
int t,i,j,k;
cin>>t;
while(t--)
{
scanf("%s",s);
int n=strlen(s);
memset(dp,0x3f3f3f3f,sizeof(dp));
dp[][]=;
for(i=; i<n; i++)
{
dp[i][i]=;
dp[i][i-]=;
}
for(int len=; len<=n; len++)
for(i=; i<=n-len; i++)
{
j=i+len-;
if(s[i]=='['&&s[j]==']'||s[i]=='('&&s[j]==')')
dp[i][j]=dp[i+][j-];
for(k=i; k+<=j; k++)//这里不是else
dp[i][j]=min(dp[i][k]+dp[k+][j],dp[i][j]);
}
printf("%d\n",dp[][n-]);
}
}
4.【nyoj746】整数划分(四)
传送门:点击打开链接
给出两个整数 n , m ,要求在 n 中加入m - 1 个乘号,将n分成m段,求出这m段的最大乘积
- 输入
- 第一行是一个整数T,表示有T组测试数据
接下来T行,每行有两个正整数 n,m ( 1<= n < 10^19, 0 < m <= n的位数); - 输出
- 输出每组测试样例结果为一个整数占一行
- 样例输入
-
2
111 2
1111 2 - 样例输出
-
11
121思路:
由于最大的划分所有的乘号都是固定的,可以从前到后以此找出所有乘号的位置,找出最优子结构(从结论入手向前拆分问题)。
- dp[i][j]代表0到i个数字中添加j个乘号,要求dp[n][m]即求dp[k][m-1]*a[k+1][i],应用到所有dp[i][j]=max(dp[i][j],dp[k][j-1]*a[k+1][i]),a[i][j]是从i到j的组合数。
#include<bits/stdc++.h>
using namespace std;
typedef long long LL;
LL dp[][],a[][];
char s[];
int main()
{
LL n,m,t,i,j,k;
cin>>t;
while(t--)
{
scanf("%s%lld",s,&m);
n=strlen(s);
memset(dp,,sizeof(dp));
for(i=; i<n; i++)
a[i][i]=s[i]-'';
for(i=; i<n-; i++)
for(j=i+; j<n; j++)
a[i][j]=a[i][j-]*+(s[j]-'');
for(i=; i<n; i++)
dp[i][]=a[][i];
for(j=; j<=m-; j++)
for(i=; i<n; i++)
for(k=; k+<=i; k++)
dp[i][j]=max(dp[i][j],dp[k][j-]*a[k+][i]);
printf("%lld\n",dp[n-][m-]);
}
return ;
}
【专题】区间dp的更多相关文章
- kuangbin专题十二 POJ3186 Treats for the Cows (区间dp)
Treats for the Cows Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 7949 Accepted: 42 ...
- 「kuangbin带你飞」专题二十二 区间DP
layout: post title: 「kuangbin带你飞」专题二十二 区间DP author: "luowentaoaa" catalog: true tags: - ku ...
- 区间dp专题练习
区间dp专题练习 题意 1.Equal Sum Partitions ? 这嘛东西,\(n^2\)自己写去 \[\ \] \[\ \] 2.You Are the One 感觉自己智力被吊打 \(dp ...
- [kuangbin带你飞]专题二十二 区间DP
ID Origin Title 17 / 60 Problem A ZOJ 3537 Cake 54 / 105 Problem B LightOJ 1422 Hallowee ...
- 专题训练之区间DP
例题:以下例题部分的内容来自https://blog.csdn.net/my_sunshine26/article/details/77141398 一.石子合并问题 1.(NYOJ737)http: ...
- UESTC 2015dp专题 A 男神的礼物 区间dp
男神的礼物 Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://acm.uestc.edu.cn/#/contest/show/65 Descri ...
- 区间dp专题
HDU4283You Are the One区间dp, 记忆话搜索运行时间: #include <iostream> #include <cstdio> #include ...
- P1040 加分二叉树 区间dp
题目描述 设一个nn个节点的二叉树tree的中序遍历为(1,2,3,…,n1,2,3,…,n),其中数字1,2,3,…,n1,2,3,…,n为节点编号.每个节点都有一个分数(均为正整数),记第ii个节 ...
- hdu 2476 区间dp
题意: 给出两个串s1和s2,一次只能将一个区间刷一次,问最少几次能让s1=s2 例如zzzzzfzzzzz,长度为11,我们就将下标看做0~10 先将0~10刷一次,变成aaaaaaaaaaa 1~ ...
随机推荐
- window7+wamp环境配置Oracle数据库连接
最近开发需要使用的oracle数据库!翻看了PHP手册,也在网上找了些帖子!功夫不负有心人,花费了四五个小时的时间,终于找到了Oracle的配置方法.下面就讲解下如何配置Oracle数据库连接吧! 附 ...
- jmeter 非GUI模式下测试报错An error occurred: Unknown arg:
D:\download\性能工具\JMeter\apache-jmeter-2.11\apache-jmeter-2.11\bin>jmeter -n -t E:\性能测试\jmeter scr ...
- go——字典(二)
字典是一种数据结构,用于存储一系列无序的键值对. 字典是基于键来存储值.字典功能强大的地方是能够基于键快速检索数据. 键就像索引一样,指向与键关联的值. 1.内部实现 字典是一个集合,可以使用类似处理 ...
- 运用SQLAlchemy
result = engine.execute(s) for row in result: Info["UserId"]=row[0] Info["UserTitle&q ...
- 微信小程序组件checkbox
表单组件checkbox:官方文档 Demo Code: JS Page({ data:{ items:[ {name: 'USA', value: '美国'}, {name: 'CHN', valu ...
- 转:asp.net获取url各项参数
假设当前页完整地址是:http://www.test.com/aaa/bbb.aspx?id=5&name=kelli "http://"是协议名 "www.te ...
- error C2665: “std::locale::facet::operator new”: 2 个重载中没有一个可以转换所有参数类型
qt项目 qt creator项目由插件自动转换成的vs2015项目,为了发布少带些dll ,切换成vs2013项目,在更改了一些vs2013不支持的c++新标准写法之后,release可正常编过,但 ...
- CentOS6、7优化脚本完美版
#!/bin/bash SysVer=`cat /etc/redhat-release | awk -F'release' '{print $2}' | awk -F'[ .]+' '{print $ ...
- jz2440存储管理实验【学习笔记】
平台:jz2440 作者:庄泽彬(欢迎转载,请注明作者) 说明:韦东山一期视频学习笔记 简介:先来简单的说明一下这次的实验,看看下图,我们的程序通过烧录器下载到nandflash当中去,之后在启动的时 ...
- Spring注解(环境)
以数据库为例: 引入 c3p0数据源maven坐标 数据库驱动 @Configuration @PropertySource("classpath:/db.config.properties ...