#include <stdio.h>

int main() {
    int n;
    scanf("%d", &n);
    int arr[n];
    int dp_l[n];
    int dp_r[n];
    for (int i = 0; i < n; i++) {
        scanf("%d", &arr[i]);
        dp_r[i] = dp_l[i] = 1;
    }
    //计算左侧最长递增子序列
    for (int i = 1; i < n; i++) {
        for (int j = 0; j < i; j++) {
            if (arr[i] > arr[j]) {
                dp_l[i] = dp_l[i] > dp_l[j] + 1 ? dp_l[i] : dp_l[j] + 1;
            }
        }
    }
    //计算右侧最长递减子序列
    for (int i = n - 2; i >= 0; i--) {
        for (int j = n - 1; j > i; j--) {
            if (arr[i] > arr[j]) {
                dp_r[i] = dp_r[j] + 1 > dp_r[i] ? dp_r[j] + 1 : dp_r[i];
            }
        }
    }
    int max = 0;
    for (int i = 0; i < n; i++) {
        if (dp_r[i] + dp_l[i] > max) {
            max = dp_l[i] + dp_r[i] - 1;
        }
    }
    printf("%d", n - max);
    return 0;
}