Submission #1229409

#TimeUsernameProblemLanguageResultExecution timeMemory
1229409almaharbas4Group Photo (JOI21_ho_t3)C++20
100 / 100
315 ms516 KiB
#include<bits/stdc++.h>
using namespace std;
int maxn=5005;
vector<int> bit(maxn),dp(maxn),pref(maxn);
void update(int i,int a,int n)
{
    for(;i<=n;i+=i&-i) bit[i]+=a;
}
int sum(int i)
{
    int s=0;
    for(;i;i-=i&-i) s+=bit[i];
    return s;
}
int main()
{
    int n;
    cin>>n;
    vector<int> v(maxn);
    vector<int> pos(maxn);
    for(int i=1;i<=n;i++) 
    {
        cin>>v[i];
        pos[v[i]]=i;
        dp[i]=1e9;
    }
    for(int i=1;i<=n;i++)
    {
        int s=0;
        for(int j=1;j<=n;j++) pref[j]=pref[j-1]+(v[j]>=i);
        for(int j=i;j<=n;j++)
        {
            s+=pref[pos[j]]-j+i-1+sum(pos[j]);
            dp[j]=min(dp[j],dp[i-1]+s);
            update(pos[j],1,n);
        }
        for(int j=0;j<=n;j++) bit[j]=0;
    }
    cout<<dp[n]<<endl;
    return 0;
}
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...