CodeTON Round 5 c ( dp

cpp 复制代码
#include<bits/stdc++.h>
using namespace std ;
using ll = long long;
using PII = pair<int,int>;
//using = pair<int,int>;
using VI = vector<int>;
const int mod = 10007;
const int limit = 30000;
int n,m,s;
int x;

int count_1(ll x){
    int res=0;
    while(x){
        res += x&1;
        x = x>>1;
    }
    return res;
}


void solve(){
    cin>>n;
    VI a(n+2);
    VI l(n+2,-0x3f3f3f3f);
    VI dp(n+2,0);
    for(int i=1;i<=n;i++) cin>>a[i];

    for(int i=1;i<=n;i++){
        dp[i] = dp[i-1];
        dp[i] = max(dp[i],i + l[a[i]]);
        l[a[i]] = max(l[a[i]] , dp[i-1]-i+1);
    }
    cout<<dp[n]<<"\n";
}

int main(){
    int t;
    cin>>t;
    while(t--){
        solve();

    }
}

先考虑构建一个朴素的做法

dp[i] = max(dp[i-1] , dp[j-1] + i - j +1) j <= i && a[j] == a[i]

很明显这是一个二重循环,但对于在一次 j 的循环中,dp[j-1] + i - j +1 其中i是不变的,

所以只需要记录下每个数字的最大的 dp[j-1] - j + 1 就可以在O(1) 时间内实现转移

相关推荐
普贤莲花9 分钟前
【2026年第11周---写于20260322】
程序人生·算法·leetcode
小白自救计划12 分钟前
力扣知识点杂集
算法·leetcode·哈希算法
阿贵---15 分钟前
分布式系统C++实现
开发语言·c++·算法
不染尘.16 分钟前
最短路径之Bellman-Ford算法
开发语言·数据结构·c++·算法·图论
big_rabbit050219 分钟前
JVM堆内存查看命令
java·linux·算法
m0_6625779721 分钟前
C++中的RAII技术深入
开发语言·c++·算法
旖-旎21 分钟前
二分查找(点名)(8)
c++·算法·二分查找·力扣
承渊政道24 分钟前
【优选算法】(实战体验滑动窗口的奇妙之旅)
c语言·c++·笔记·学习·算法·leetcode·visual studio
lemonth26 分钟前
图形推理----
人工智能·算法·机器学习
2401_8914821737 分钟前
C++代码复杂性分析
开发语言·c++·算法