原文链接https://www.cnblogs.com/zhouzhendong/p/CF264C.html
题意
给定一个有 $n$ 个元素的序列,序列的每一个元素是个球,第 $i$ 个球具有 $v_i$ 的值,颜色为 $c_i$ 。
一个序列的价值为每一个球价值和。
在一个序列中,第 $i$ 个球的价值为:
当 $c_i=c_{i-1}(i>1)$ 时,$value=av_i$。
否则, $value=bv_i$ 。
接下来有 $q$ 组询问,每组询问给定 $a,b$ ,问在当前给定的 $a,b$ 下,原序列所有子序列(不一定要连续)的价值中的最大值。
$n\leq 10^5,q\leq 500$
题解
扫描二维码关注公众号,回复:
2092347 查看本文章
代码
#include <bits/stdc++.h> using namespace std; typedef long long LL; const int N=100005; const LL INF=1LL<<56; LL read(){ int x; scanf("%d",&x); return 1LL*x; } int n,q,c[N]; LL v[N],dp[N]; int main(){ scanf("%d%d",&n,&q); for (int i=1;i<=n;i++) v[i]=read(); for (int i=1;i<=n;i++) scanf("%d",&c[i]); while (q--){ LL a=read(),b=read(); LL ans=0; int Max=0,Nxt=0; for (int i=0;i<=n;i++) dp[i]=-INF; for (int i=1;i<=n;i++){ int color=c[i]; LL now=max(dp[color]+a*v[i],b*v[i]); if (color!=Max) now=max(now,dp[Max]+b*v[i]); else/* if (color!=Nxt)*/ now=max(now,dp[Nxt]+b*v[i]); if (now>dp[Max]){ if (Max!=color) Nxt=Max,Max=color; } else if (now>dp[Nxt]&&color!=Max) Nxt=color; dp[color]=max(dp[color],now); ans=max(ans,now); } printf("%I64d\n",ans); } return 0; }