题目描述
线性dp+数组优化(简洁代码)
样例
#include<iostream>
#include<cstring>
#include<algorithm>
#include<cmath>
using namespace std;
const int N=100010;
int a[N];
int f[N];
int g[10];
int main()
{
int n;
cin>>n;
for(int i=1;i<=n;i++) scanf("%d",&a[i]);
int res=0;
for(int i=1;i<=n;i++)
{
f[i]=1;
f[i]=max(f[i],g[a[i]/(int)pow(10,to_string(a[i]).size()-1)]+1);
g[a[i]%10]=max(f[i],g[a[i]%10]);
res=max(res,f[i]);
}
cout<<n-res<<endl;
}