#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const int N=1e5+5;
const ll inf=1e18;
int a[N],n,m,L,R,cnt[N];
ll g[N],f[N],ans;
void Add(int x) {ans+=cnt[a[x]]++;}
void Del(int x) {ans-=--cnt[a[x]];}
ll val(int l,int r) {
while(L<l)Del(L++);
while(L>l)Add(--L);
while(R>r)Del(R--);
while(R<r)Add(++R);
return ans;
}
void solve(int L,int R,int l,int r) {
if(L==R) {for(int i=l;i<=r;i++)f[i]=g[L]+val(L+1,i);return;}
int mid=(l+r)>>1,pos;
for(int i=L,mn=min(R,mid-1);i<=mn;i++) {
ll w=g[i]+val(i+1,mid);
if(w<f[mid]) f[mid]=w,pos=i;
}
if(l==r) {return;}
solve(L,pos,l,mid);solve(pos,R,mid+1,r);
}
int main() {
scanf("%d%d",&n,&m);
L=1,R=0;
for(int i=1;i<=n;i++) scanf("%d",&a[i]);
for(int i=0;i<=n;i++)f[i]=g[i]=inf; g[0]=0;
for(int j=1;j<=m;j++) {
solve(0,n-1,1,n);
for(int i=0;i<=n;i++)g[i]=f[i],f[i]=inf;
}
printf("%lld",g[n]);
return 0;
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· winform 绘制太阳,地球,月球 运作规律
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人