DP:Cheapest Palindrome(POJ 3280)

            

               价值最小回文字符串

  题目大意:给你一个字符串,可以删除可以添加,并且每一次对一个字母的操作都带一个权,问你转成回文串最优操作数。

  如果这一题我这样告诉你,你毫无疑问知道这一题是LD(Levenshtien Distance 编辑距离),但是上面太多废话了,理解起来还是要有点费劲,比如我一开始就觉得回文串只能从头或者尾添加(英语吃了翔╮(╯▽╰)╭)。

  好吧,其实这一题不是水题(我的感觉),这一题挺好的,是一个带权的编辑距离问题,因为最后还是老问题,问你最小值,所以马上想到用二维矩阵,但是这一题首先要解决两个陷阱。

  第一个陷阱就是题目回文串,其实这一题和回文串关系都没有,就是在基准状态(空串或者一个字母的时候用到)。

  第二个陷阱就是删除和加入的问题,你仔细看一下题目给的条件,你会发现这两个权都是正的,都尼玛是正的,这说明这两个操作都是等效的(有点像LD),最后要你找到最小值,所以我们只用关注最小的那个值就可以了

  但是回文串我们不可能全部枚举出来,而且LD要求的是固定字串,那么怎么办?其实我们可以这样,从最小开始,一个一个小串找,反正删除和加入都是等价操作,我们可以把这些操作的最小操作数都记录下来,那么最后要求的值就在dp[0][length-1]上了

  状态转移方程几乎和LD是一样的,只是少了input[j]!=input[i]时,与dp[i+1][j-1]的比较(这相当于修改了,修改也就是删除+加入,肯定不合理)

  dp[i][j]=dp[i+1][j-1]; input[i]==input[j];

  dp[i][j]=min{min(dp[i+1][j]+add[input[i]],dp[i][j]),min(dp[i][j-1]+add[input[j]]+add[input[j]])};

  

  参考:http://blog.csdn.net/y990041769/article/details/24259569

 1 #include <stdio.h>
 2 #include <stdlib.h>
 3 #define MAX_N 2001
 4 #define MIN(a,b) ((a)<(b)?(a):(b))
 5
 6 static int word_dist[26];
 7 static char input[MAX_N];
 8 static int dp[MAX_N][MAX_N];
 9
10 void Search(const int, const int);
11
12 int main(void)
13 {
14     int string_length, c_word_sum, i, tmp_add, tmp_de;
15     char tmp;
16
17     while (~scanf("%d%d", &c_word_sum, &string_length))
18     {
19         getchar();//除掉回车
20         scanf("%s", input);
21         for (i = 0; i < c_word_sum; i++)
22         {
23             getchar();//除掉回车
24             scanf("%c", &tmp);
25             scanf("%d%d", &tmp_add, &tmp_de);
26             word_dist[tmp - ‘a‘] = MIN(tmp_add, tmp_de);
27         }
28         Search(string_length, c_word_sum);
29     }
30     return 0;
31 }
32
33 void Search(const int string_length, const int c_word_sum)
34 {
35     //最后最小值会继承到dp[0][string_length - 1]
36     int i, j, k;
37     for (i = 1; i < string_length; i++)
38     {
39         for (j = 0, k = i; k < string_length; j++, k++)
40         {
41             dp[j][k] = INT_MAX;
42             if (input[j] == input[k])
43                 dp[j][k] = dp[j + 1][k - 1];
44             else
45             {
46                 dp[j][k] = MIN(dp[j + 1][k] + word_dist[input[j] - ‘a‘], dp[j][k]);
47                 dp[j][k] = MIN(dp[j][k - 1] + word_dist[input[k] - ‘a‘], dp[j][k]);
48             }
49         }
50     }
51     printf("%d\n", dp[0][string_length - 1]);
52 }
时间: 2024-08-25 20:56:02

DP:Cheapest Palindrome(POJ 3280)的相关文章

挑战程序设计竞赛2.3习题:Cheapest Palindrome POJ - 3280

Keeping track of all the cows can be a tricky task so Farmer John has installed a system to automate it. He has installed on each cow an electronic ID tag that the system will read as the cows pass by a scanner. Each ID tag's contents are currently a

POJ 3280 Cheapest Palindrome DP题解

看到Palindrome的题目,首先想到的应该是中心问题,然后从中心出发,思考如何解决. DP问题一般是从更加小的问题转化到更加大的问题,然后是从地往上 bottom up地计算答案的. 能得出状态转移方程就好办了,本题的状态转移方程是: if (cowID[i] == cow{j]) tbl[id][i] = tbl[id][i+1];//相等的时候无需改动 else tbl[id][i] = min(tbl[!id][i+1] + cost[cowID[i]-'a'], tbl[!id][i

POJ 3280:Cheapest Palindrome 区间DP好题

Cheapest Palindrome 题目链接: http://poj.org/problem?id=3280 题意: 给出一个只由小写字母组成的串,可以添加或删除一些字母(添加和删除都需要花费且花费不同),求将这个串改变成一个回文串的最小花费. 题解: 设dp[i][j]是将区间[i,j]改变成回文串的最小花费,则两种情况 ①显而易见,当s[i]==s[j]时,dp[i][j]=dp[i+1][j-1] ②当s[i]!=s[j]时,dp[i][j]有四种可能的取值,区间 [i,j-1] 删除

POJ 3280 Cheapest Palindrome(DP)

题目链接 题意 :给你一个字符串,让你删除或添加某些字母让这个字符串变成回文串,删除或添加某个字母要付出相应的代价,问你变成回文所需要的最小的代价是多少. 思路 :DP[i][j]代表的是 i 到 j 这一段位置变成回文所需的最小的代价. 1 //3280 2 #include <stdio.h> 3 #include <string.h> 4 #include <iostream> 5 6 using namespace std ; 7 8 char sh[2100]

POJ 3280 Cheapest Palindrome(区间DP)

 Cheapest Palindrome Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 6894   Accepted: 3344 Description Keeping track of all the cows can be a tricky task so Farmer John has installed a system to automate it. He has installed on each co

poj 3280 Cheapest Palindrome(区间DP)

Cheapest Palindrome Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 5995   Accepted: 2922 Description Keeping track of all the cows can be a tricky task so Farmer John has installed a system to automate it. He has installed on each cow a

【POJ】3280 Cheapest Palindrome(区间dp)

Cheapest Palindrome Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 10943   Accepted: 5232 Description Keeping track of all the cows can be a tricky task so Farmer John has installed a system to automate it. He has installed on each cow

[poj]3280 Cheapest Palindrome 题解

[poj]3280 Cheapest Palindrome 区间dp 题意: 给你长度为m的字符串,其中有n种字符,每种字符都有两个值,分别是插入这个字符的代价,删除这个字符的代价,让你求将原先给出的那串字符变成一个回文串的最小代价. M<=2000 设 dp[i][j] 为区间 i~j 的回文串的最小代价 现在考虑怎样从别的状态转移到 区间i~j 三种情况 首先 str[i]==str[j] 那么 dp[i][j] = dp[i+1][j-1] 其次 (i+1)~j 是一个回文串 dp[i][

poj 3280(区间DP)

Cheapest Palindrome Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 7869   Accepted: 3816 Description Keeping track of all the cows can be a tricky task so Farmer John has installed a system to automate it. He has installed on each cow a