博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
紫书 例题 9-7 UVa 11584 (线性结构上的动态规划)
阅读量:5828 次
发布时间:2019-06-18

本文共 940 字,大约阅读时间需要 3 分钟。

这道题判断回文串的方法非常的秀!

这里用到了记忆化搜索,因为会有很多重复
同时用kase来区分每一组数据
然后还有用递归来判断回文,很简洁

然后这种线性结构的动态规划的题,就是把

当前的这个数组分成两块来枚举,一块是之前已经得出的最优解,
一块是自己现在按照题目要求来算出的值,这样枚举下去。
然后要注意初始化的问题,同时注意这有后面自己算的这一块占
了全部的情况,可以以此为初始的值。
一定要给初始的值,不然答案可能全是0

#include
#include
#include
#define REP(i, a, b) for(int i = (a); i < (b); i++)using namespace std;const int MAXN = 1123;int vis[MAXN][MAXN], d[MAXN], p[MAXN][MAXN], kase;char s[MAXN];bool judge(int i, int j){ if(i >= j) return true; if(s[i] != s[j]) return false; if(vis[i][j] == kase) return p[i][j]; vis[i][j] = kase; return p[i][j] = judge(i + 1, j - 1);}int main(){ int T; scanf("%d", &T); for(kase = 1; kase <= T; kase++) { scanf("%s", s + 1); int n = strlen(s + 1); d[0] = 0; REP(i, 1, n + 1) { d[i] = i; REP(j, 0, i) if(judge(j + 1, i)) d[i] = min(d[i], d[j] + 1); } printf("%d\n", d[n]); } return 0;}

 

转载于:https://www.cnblogs.com/sugewud/p/9819454.html

你可能感兴趣的文章
如何通过Dataworks禁止MaxCompute 子账号跨Project访问
查看>>
js之无缝滚动
查看>>
Django 多表联合查询
查看>>
logging模块学习:basicConfig配置文件
查看>>
Golang 使用 Beego 与 Mgo 开发的示例程序
查看>>
+++++++子域授权与编译安装(一)
查看>>
asp.net怎样在URL中使用中文、空格、特殊字符
查看>>
路由器发布服务器
查看>>
实现跨交换机VLAN间的通信
查看>>
jquery中的data-icon和data-role
查看>>
python例子
查看>>
环境变量(总结)
查看>>
ios之UILabel
查看>>
Java基础之String,StringBuilder,StringBuffer
查看>>
1月9日学习内容整理:爬虫基本原理
查看>>
安卓中数据库的搭建与使用
查看>>
AT3908 Two Integers
查看>>
渐变色文字
查看>>
C++ 0X 新特性实例(比较常用的) (转)
查看>>
node生成自定义命令(yargs/commander)
查看>>