算法 Longest Repeated Sequence(最大重复子序列 微软编程一小时 题目2)

先写下思路

序列问题一般要向二分,递归,DP等方法上考虑

这里要用到DP

状态方程应该是

A(n)=max{A(n-1),A(n-1)+1};

何时+1是关键所在:

联想一下最长递增子序列问题,明显可以用O(n*n*n)解决该问题

利用 编程之美上的保存最大子序列数组的方法可以进一步优化到O(n*n)

这里也要用到KMP的模式思想,如果n-1序列上已经第一次匹配,则n序列上就只用比较max[2]上保存的序列位置


// by zjerry 思路不完整,未编程,暂时放一放

参考:

http://blog.csdn.net/wu_george/article/details/22994891

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值