#include<iostream>
#include<vector>
#include<algorithm>
using namespace std;
int main()
{
	int n;
	cin>>n;
	int arr[1000];
	int dp[1000];//dp[i]存放的是以arr[i]为结尾的最长递增子序列长度(不必连续) 
	int dp2[1000];//dp2[i]存放的是以arr[i]开始的最长递减子序列长度(不必连续) 
	for(int i=0;i<n;i++)
	{
		cin>>arr[i];
	}
	
	for(int i=0;i<n;i++)
	{
		dp[i]=1;
		for(int j=0;j<i;j++)
		{
			if(arr[j]<arr[i])
			{
				dp[i]=max(dp[i],dp[j]+1);
			}
		}
	}
	for(int i=n-1;i>=0;i--)
	{
		dp2[i]=1;
		for(int j=n-1;j>i;j--)
		{
			if(arr[j]<arr[i])
			{
				dp2[i]=max(dp2[i],dp2[j]+1);
			}
		}
	}
	
	int maxnum=0;
	for(int i=0;i<n;i++)
	{
		maxnum=max(maxnum,dp[i]+dp2[i]-1);////
	}
	cout<<n-maxnum<<endl;
	return 0;
}