博客
关于我
Codeforces Round #336 (Div. 1) B. Zuma(区间DP&&记忆化)
阅读量:386 次
发布时间:2019-03-05

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

在这里插入图片描述
题意:你可以删除一个回文序列,问你最少操作几次能删完。
思路:这里提供两个思路,一个是常见的枚举区间,第二个是记忆化,dp【l】【r】代表区间【l,r】删完的最少次数。
枚举区间:

#include
using namespace std;typedef long long ll;int n,dp[501][501],a[501];int main(){ scanf("%d",&n); for(int i=1;i<=n;++i) scanf("%d",&a[i]); memset(dp,0x3f,sizeof(dp)); for(int i=1;i<=n;++i) dp[i][i]=1; for(int len=2;len<=n;++len) { for(int l=1;l+len-1<=n;++l) { int r=l+len-1; if(l+1==r) dp[l][r]=((a[l]==a[r])?1:2); for(int k=l;k

记忆化:

#include
using namespace std;typedef long long ll;int n,dp[501][501],a[501];const int inf=0x3f3f3f3f;int dfs(int l,int r){ if(l==r) return dp[l][r]=1; if(l>r) return 1; if(dp[l][r]!=inf) return dp[l][r]; int ans=inf; if(a[l]==a[r]) ans=min(ans,dfs(l+1,r-1)); for(int k=l;k

转载地址:http://sgewz.baihongyu.com/

你可能感兴趣的文章
Netty中集成Protobuf实现Java对象数据传递
查看>>
netty之 定长数据流处理数据粘包问题
查看>>
Netty事件注册机制深入解析
查看>>
netty代理
查看>>
Netty入门使用
查看>>
netty入门,入门代码执行流程,netty主要组件的理解
查看>>
Netty原理分析及实战(一)-同步阻塞模型(BIO)
查看>>
Netty原理分析及实战(三)-高可用服务端搭建
查看>>
Netty原理分析及实战(二)-同步非阻塞模型(NIO)
查看>>
Netty原理分析及实战(四)-客户端与服务端双向通信
查看>>
Netty发送JSON格式字符串数据
查看>>
Netty和Tomcat的区别已经性能对比
查看>>
Netty在IDEA中搭建HelloWorld服务端并对Netty执行流程与重要组件进行介绍
查看>>
Netty基础—1.网络编程基础一
查看>>
Netty基础—1.网络编程基础二
查看>>
Netty基础—2.网络编程基础三
查看>>
Netty基础—2.网络编程基础四
查看>>
Netty基础—3.基础网络协议一
查看>>
Netty基础—3.基础网络协议二
查看>>
Netty基础—4.NIO的使用简介一
查看>>