poj-3898 Software Industry Revolution DP
题目链接:
http://poj.org/problem?id=3898
题目意思:
有两个字符串,模式串和原串。每个字母有一个权值,a为1,b为2,...z为26
模式串中‘ ?’可以被一个字母代替。
‘*’可以被0个或多个字母代替。
问替换后的模式串满足时原串的子串,求权值和最小的那个值。
解题思路:
dp[i][j]表示模式串的第i个字符和原串的第j个字符匹配时,能达到的最小的权值。
当save1[i]==save2[j]时,dp[i][j]=min(dp[i][j],dp[i-1][j-1]+save2[j]-'0');
当save1[i]=='*'时,dp[i][j]=min(dp[i][j],dp[i-1][k]+sum[j]-sum[k])(0<=k<=j);
当save1[i]=='?'时,dp[i][j]=min(dp[i][j],dp[i-1][j-1]+save2[j]-'0');
用lmin[j]保存下表示不超过j的最小的dp[i-1][k]-sum[k] 则lmin[j]=min(lmin[j-1],dp[i-1][j]-sum[j]);
用lmin[j]数组可以把复杂度降很多。以后要多加留意呵呵。
代码:
#include<iostream>
#include<cmath>
#include<cstdio>
#include<cstdlib>
#include<string>
#include<cstring>
#include<algorithm>
#include<vector>
#include<map>
#include<set>
#include<stack>
#include<list>
#include<queue>
#define eps 1e-6
#define INF 0x1f1f1f1f
#define PI acos(-1.0)
#define ll __int64
#define lson l,m,(rt<<1)
#define rson m+1,r,(rt<<1)|1
using namespace std; /*
freopen("data.in","r",stdin);
freopen("data.out","w",stdout);
*/
int dp[1100][11000];
int sum[11000],lmin[11000];
char save1[1100],save2[11000]; int main()
{
while(scanf("%s%s",save1+1,save2+1)!=EOF)
{
int le1=strlen(save1+1),le2=strlen(save2+1); //printf("%d %d\n",le1,le2);
sum[0]=0;
for(int i=1;i<=le2;i++) //sum[i]表示前i个,权值之和
sum[i]=save2[i]-'a'+1+sum[i-1];
for(int i=0;i<=le1;i++) //初始化为最大
for(int j=0;j<=le2;j++)
dp[i][j]=INF;
dp[0][0]=0;
lmin[0]=INF; //用lmin[j]保存下表示不超过j的最小的dp[i-1][k]-sum[k]
//则lmin[j]=min(lmin[j-1],dp[i-1][j]-sum[j])
for(int i=1;i<=le2;i++)
{
dp[0][i]=0;
lmin[i]=min(lmin[i-1],dp[0][i]-sum[i]);
}
bool flag=false;
for(int i=1;i<=le1;i++)
{
lmin[0]=INF;
flag=false;
if(dp[i-1][0]==0) //说明前面有‘*’号的情况
{
if(save1[i]=='*')
{
dp[i][0]=0;
flag=true; //注意这个不能掉
}
}
for(int j=1;j<=le2;j++)
{
if(save1[i]=='?') //当为?号时,可以用任意字母代替
{
if(dp[i-1][j-1]+save2[j]-'a'+1<dp[i][j])
{
flag=true;
dp[i][j]=dp[i-1][j-1]+save2[j]-'a'+1;
}
}
else if(save1[i]=='*') //当为‘*’时,找到lmin[j],用它来更新
{
if(lmin[j]+sum[j]<dp[i][j])
{
flag=true;
dp[i][j]=lmin[j]+sum[j];
}
}
else if(save1[i]==save2[j]) //直接更新过来
{
if(dp[i-1][j-1]+save2[j]-'a'+1<dp[i][j])
{
dp[i][j]=dp[i-1][j-1]+save2[j]-'a'+1;
flag=true;
}
}
lmin[j]=min(lmin[j-1],dp[i][j]-sum[j]);
//printf("i:%d j:%d %d ",i,j,dp[i][j]);
}
if(!flag) //减一下枝
break;
//putchar('\n');
}
int ans=INF;
for(int j=1;j<=le2;j++)
ans=min(ans,dp[le1][j]);
if(ans==INF)
puts("-1");
else
printf("%d\n",ans);
} return 0;
}
poj-3898 Software Industry Revolution DP的更多相关文章
- {POJ}{3988}{Software Industry Revolution}{DP好题}
题意:给定一个字符串d,要求用另一字符串s去匹配,其中s中的?可以为任何字符,*可以为任意个字符,求最小的匹配权值 思路:这题和CSDN英雄会的“反相互”类似,由于其中某些字符的不确定性,利用动态规划 ...
- 【POJ 3071】 Football(DP)
[POJ 3071] Football(DP) Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 4350 Accepted ...
- poj 3311(状态压缩DP)
poj 3311(状态压缩DP) 题意:一个人送披萨从原点出发,每次不超过10个地方,每个地方可以重复走,给出这些地方之间的时间,求送完披萨回到原点的最小时间. 解析:类似TSP问题,但是每个点可以 ...
- poj 1185(状态压缩DP)
poj 1185(状态压缩DP) 题意:在一个N*M的矩阵中,‘H'表示不能放大炮,’P'表示可以放大炮,大炮能攻击到沿横向左右各两格,沿纵向上下各两格,现在要放尽可能多的大炮使得,大炮之间不能相互 ...
- poj 3254(状态压缩DP)
poj 3254(状态压缩DP) 题意:一个矩阵里有很多格子,每个格子有两种状态,可以放牧和不可以放牧,可以放牧用1表示,否则用0表示,在这块牧场放牛,要求两个相邻的方格不能同时放牛,即牛与牛不能相 ...
- poj 2324 Anniversary party(树形DP)
/*poj 2324 Anniversary party(树形DP) ---用dp[i][1]表示以i为根的子树节点i要去的最大欢乐值,用dp[i][0]表示以i为根节点的子树i不去时的最大欢乐值, ...
- Poj 1973 Software Company(二分+并行DP)
题意:软件公司接了两个项目,来自同一个合同,要一起交付.该公司有n个程序猿来做这两个项目A和B,每个项目都被分为m个子项目,给定每个程序猿做一个A中的子项目需要的时间Xi秒,和做B中的子项目所需时间Y ...
- Software Industry Revolution----POJ3898----DP
题目地址:http://poj.org/problem?id=3898 题目意思: 给你一个模式串,再给你一个原串,要你去匹配 模式串里面的?可对应任意一个字符 *号可对应0个或多个字符 其中a=1, ...
- POJ 2096 Collecting Bugs 期望dp
题目链接: http://poj.org/problem?id=2096 Collecting Bugs Time Limit: 10000MSMemory Limit: 64000K 问题描述 Iv ...
随机推荐
- ASP.NET 依赖注入。
ASP.NET 依赖注入. http://www.it165.net/pro/html/201407/17685.html 我在网上看到了这篇文章,这边文章主要说的方法就是通过读取配置文件来解决依赖注 ...
- .net 职责链来实现 插件模式
.net 职责链来实现 插件模式 插件式的例子 QQ电脑管家,有很多工具列表,点一下工具下载后就可以开始使用了 eclipse ,X Server 等等 插件式的好处 插件降低框架的复杂性,把扩展功能 ...
- C语言库函数大全及应用实例十一
原文:C语言库函数大全及应用实例十一 [编程资料]C语言库函数大全及应用实例十一 函数名: setbkcolor 功 能 ...
- java设计模式之六适配器模式(Adapter)
适配器模式将某个类的接口转换成客户端期望的另一个接口表示,目的是消除由于接口不匹配所造成的类的兼容性问题.主要分为三类:类的适配器模式.对象的适配器模式.接口的适配器模式.首先,我们来看看类的适配器模 ...
- 【麦子学院】OpenCV教程函数总结
个自带样例. parter 1: No1. adaptiveskindetector.cpp 利用HSV空间的色调信息的皮肤检測,背景不能有太多与肤色相似的颜色.效果不是特别好. No2. bagof ...
- tornado settings想到的
今天有足够多的时间来看看Tornado中RequestHandler和Application这两个类的关系. 昨天想要调用settings中的内容,找了好半天不知道怎么在handler中使用setti ...
- sql2005还原超长sql脚本,还原超大脚本文件
原文:sql2005还原超长sql脚本,还原超大脚本文件 从外网把数据库用导出脚本的方式导出来了,280M的样子,导是导出来了,但是在本机执行sql脚本的时候,直接就是out of memory,之前 ...
- javascript 学习总结(七)String对象
1.string对象中可以传正则的函数介绍 /* match() 方法可在字符串内检索指定的值,或找到一个或多个正则表达式的匹配. 该方法类似 indexOf() 和 lastIndexOf(),但是 ...
- Scala是一门现代的多范式编程语言
Scala是一门现代的多范式编程语言 Scala是一门现代的多范式编程语言,志在以简练.优雅及类型安全的方式来表达常用编程模式.它平滑地集成了面向对象和函数语言的特性. Scala是面向对象的:Sca ...
- NET Framework 4.5新特性 数据库的连接加密保护。
NET Framework 4.5新特性 (一) 数据库的连接加密保护. NET Framework 4.5 ado.net数据库连接支持使用SecureString内存流方式保密文本. 一旦使用这 ...