颜色扩散类dp及其优化:0919T2

http://cplusoj.com/d/senior/p/330

此题前半部分是AGC058B

这是一个颜色扩散类dp,对于这类dp,存在一个性质。

在这里插入图片描述

假如一个区间被 i i i 染,一个被 j j j 染,则必然满足 i < j i<j i<j(这是下标)

所以转移可以用前缀和优化至 O ( n 2 ) O(n^2) O(n2)

for(i=1; i<=n; ++i) {
		for(j=1, mx=0; j<=n; ++j) {
			mx=max(mx, f[i-1][j]); 
			f[i][j]=mx+(a[j]==b[i] && i>=l[j] && i<=r[j]); 
		}
	}
	for(i=1; i<=n; ++i) ans=max(f[n][i], ans); 

然后针对题目的特殊限定,我们可以发现, a j = b i a_j=b_i aj=bi 成立只有 n n n 个,所以就变成了线段树优化问题。

for(i=1; i<=n; ++i) mp[a[i]]=i; 
for(i=1; i<=n; ++i) {
	if(!mp[b[i]]) continue; 
	j=mp[b[i]];  
	if(!(i>=l[j] && i<=r[j])) continue; 
	k=Seg.add(1, 1, n, j); 
	if(j!=n) Seg.que(1, 1, n, j+1, n, k); 
}
printf("%lld", Seg.mx[1]); 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值