Submission #927841

#TimeUsernameProblemLanguageResultExecution timeMemory
927841UnforgettableplGroup Photo (JOI21_ho_t3)C++17
100 / 100
363 ms852 KiB
#include <bits/stdc++.h>
using namespace std;

#define int long long

const int INF = 1e15;

struct fenwick{
    int n;
    vector<int> tree;
    fenwick(int n):n(n),tree(n+1){}
    int get(int k){
        int ans = 0;
        while(k){
            ans+=tree[k];
            k-=k&-k;
        }
        return ans;
    }
    void add(int k){
        while(k<=n){
            tree[k]++;
            k+=k&-k;
        }
    }
};

int DP[5001];
int idx[5001];

int32_t main(){
    ios_base::sync_with_stdio(false);
    cin.tie(nullptr);
    int n;
    cin >> n;
    for(int i=1;i<=n;i++){
        int a;cin>>a;
        idx[a]=i;
    }
    fenwick elements(n);
    for(int i=1;i<=n;i++){
        elements.add(idx[i]);
        int curr = 0;
        DP[i] = INF;
        fenwick bigger(n);
        for(int j=i;j;j--){
            curr+=elements.get(n);
            curr-=elements.get(idx[j]);
            curr-=bigger.get(idx[j]);
            bigger.add(idx[j]);
            DP[i] = min(DP[i],DP[j-1]+curr);
        }
    }
    cout << DP[n] << '\n';
}
#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...