uva 11584 - 字符串 dp
一个长度1000的字符串最少划分为几个回文字符串
-----------------------------------------------------------------------------------------------------------------
想复杂了。
首先N2的时间预处理一下,从i开始长度为len的字符串是否为回文串。
dist(i) = MIN(dist(i),dist(j)+1) 如果 j-i 为一个回文串
#include <set>
#include <map>
#include <stack>
#include <queue>
#include <cmath>
#include <vector>
#include <string>
#include <cstdio>
#include <cstring>
#include <cstdlib>
#include <iostream>
#include <algorithm> #define MAX(a,b) ((a)>=(b)?(a):(b))
#define MIN(a,b) ((a)<=(b)?(a):(b))
#define OO 0x0fffffff
using namespace std;
typedef long long LL;
const int N = ;
bool dp[N][N];
int minDist[N];
char str[N];
int main(){
int n; for(cin>>n;n--;){
scanf("%s",str); int length = strlen(str); for(int i=;i<length;i++) minDist[i] = i+; memset(dp,false,sizeof(dp));
for(int len=;len<;len++) for(int i=;i<length;i++) {
dp[len][i]=true;
}
for(int len=;len<=length;len++){
for(int i=;i<length;i++){
if(len+i>length) break;
dp[len][i] = (str[i]==str[i+len-])&&(dp[len-][i+]);
}
}
for(int i=;i<length;i++){
for(int j=;j<=i;j++){
if(dp[i-j+][j]) minDist[i] = MIN(minDist[i],j?(minDist[j-]+):);
}
}
printf("%d\n",minDist[length-]);
}
return ;
} /*
3
racecar
fastcar
aaadbccb
*/
uva 11584 - 字符串 dp的更多相关文章
- Partitioning by Palindromes UVA - 11584 简单dp
		题目:题目链接 思路:预处理出l到r为回文串的子串,然后如果j到i为回文串,dp[i] = min(dp[i], dp[j] + 1) AC代码: #include <iostream> ... 
- UVA 11584 入门DP
		一开始把它当成暴力来做了,即,从终点开始,枚举其最长的回文串,一旦是最长的,马上就ans++,再计算另外的部分...结果WA了 事实证明就是一个简单DP,算出两个两个点组成的线段是否为回文,再用LCS ... 
- UVA - 11584 划分字符串的回文串子串; 简单dp
		/** 链接:http://acm.hust.edu.cn/vjudge/problem/viewProblem.action?id=34398 UVA - 11584 划分字符串的回文串子串: 简单 ... 
- uva 11584 Partitioning by Palindromes 线性dp
		// uva 11584 Partitioning by Palindromes 线性dp // // 题目意思是将一个字符串划分成尽量少的回文串 // // f[i]表示前i个字符能化成最少的回文串 ... 
- 区间DP UVA 11584 Partitioning by Palindromes
		题目传送门 /* 题意:给一个字符串,划分成尽量少的回文串 区间DP:状态转移方程:dp[i] = min (dp[i], dp[j-1] + 1); dp[i] 表示前i个字符划分的最少回文串, 如 ... 
- UVA - 11584 Partitioning by Palindromes[序列DP]
		UVA - 11584 Partitioning by Palindromes We say a sequence of char- acters is a palindrome if it is t ... 
- UVA 11584	一 Partitioning by Palindromes
		Partitioning by Palindromes Time Limit:1000MS Memory Limit:0KB 64bit IO Format:%lld & %l ... 
- UVA.10192 Vacation (DP LCS)
		UVA.10192 Vacation (DP LCS) 题意分析 某人要指定旅游路线,父母分别给出了一系列城市的旅游顺序,求满足父母建议的最大的城市数量是多少. 对于父母的建议分别作为2个子串,对其做 ... 
- 【BZOJ 2121】 (字符串DP,区间DP)
		2121: 字符串游戏 Description BX正在进行一个字符串游戏,他手上有一个字符串L,以及其他一些字符串的集合S,然后他可以进行以下操作:对于一个在集合S中的字符串p,如果p在L中出现,B ... 
随机推荐
- JQuery 登录窗口的布局
			<!-- Button trigger modal --><button type="button" class="btn btn-primary bt ... 
- Android设计模式——单例模式
			1.单例模式就是确保一个类,只有一个实例化对象,而且自行实例化并向整个系统提供这个实例. 2.使用场景: 确保某个类,有且只有一个对象,避免产生对个对象,消耗过多的资源. 2.实现单例模式的重要点: ... 
- call使用场景
			在javascript OOP中,定义: function cat(){ } cat.prototype={ food:"fish", say: funct ... 
- Javescript 面向对象编程 — 封装
			生成实例对象的原始模式 <script type="text/javascript"> var Cat={ name:'波斯猫', color:'White' } al ... 
- Unity脚本中可以引用的类型
			Hierarchy(层级视图)面板里的对象,或者 Project(工程视图)里的Prefab. 
- Django中ORM之创建模型
			ORM 数据库与ORM映射关系 表名 --- 类名 字段 --- 属性 表记录 --- 类示例对象 创建表(建立模型) 模型建立如下 class Book(models.Model): title = ... 
- python3配置爬虫开发环境
			爬虫:环境搭建 安装python3: 安装python版本:3.7.0 winsdows下的配置: 
- Spark 代码走读之 Cache
			Spark是基于内存的计算模型,但是当compute chain非常长或者某个计算代价非常大时,能将某些计算的结果进行缓存就显得很方便了.Spark提供了两种缓存的方法 Cache 和 checkPo ... 
- jboss <context /> 配置虚拟路径,映射本地文件
			这个目录下的server.xml <host><host/>标签中添加: <Context path="/file" docBase="D: ... 
- 洛谷P5238 整数校验器
			看到没有边读入边处理的,我来水一发 我们要看一下有那些情况是格式不合法的 单独的负号 -0(后面可以有其他数字) 0 +(后面一些数字) 我们用快速读入的方法 读取字符进行处理 还有可能超出范围的 考 ... 
