제출 #1330016

#제출 시각아이디문제언어결과실행 시간메모리
1330016JuanJLGroup Photo (JOI21_ho_t3)C++20
100 / 100
3854 ms1176 KiB
#include <bits/stdc++.h>
#include <ext/pb_ds/assoc_container.hpp>

#define fst first
#define snd second
#define pb push_back
#define SZ(x) (int)x.size()
#define ALL(x) x.begin(),x.end()
#define forn(i,a,b) for(int i = a; i<b;i++)
#define mset(a,v) memset(a,v,sizeof(a))
#define FIN ios::sync_with_stdio(0); cin.tie(0); cout.tie(0);

using namespace std;
using namespace __gnu_pbds;
typedef long long ll;

template< typename T >
using iset = tree<T,null_type,less<T>,rb_tree_tag,tree_order_statistics_node_update>;

const int MAXN = 5000+5;

ll n;
ll h[MAXN];
ll dp[MAXN];
ll myi[MAXN];

iset<ll> ind;

ll f(ll x){
	ll &res = dp[x];

	if(res!=-1) return res;
	if(x==n+1) return res=0;

	res=100000000000000000;

	
	//iset<ll> ind; forn(i,x,n+1) ind.insert(myi[i]);
	ll sum  = 0;
	iset<ll> men;
	
	ll aux = 0;
	forn(i,x+1,n+2){

		men.insert(myi[i-1]);	
		aux += ind.order_of_key(myi[i-1]);
		sum += SZ(men)-(men.order_of_key(myi[i-1])+1);
	
		ll paux = f(i);
		//cout<<"Estando en "<<x<<": \n";
		//cout<<"		Llendo a "<<i<<" "<<aux<<" "<<paux<<" "<<sum<<'\n';

		res=min(res, aux+paux-sum);		
	}
	return res;
}

int main(){ FIN;
	cin>>n;
	forn(i,0,n) cin>>h[i], myi[h[i]]=i;

	mset(dp,-1);
	for(int i = n; i>=0; i--){
		ind.insert(myi[i]);
		f(i);
	}
	cout<<f(1)<<'\n';
	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...