#include <iostream>
#include <cstring>
#include <algorithm>
using namespace std;
const int N = 60;
int down[N], up[N], q[N], n;
int res;
void dfs(int u, int su, int sd)
{
if (su + sd >= res) return;
if (u == n)
{
res = min(res, su + sd);
return;
}
int l = 0, r = su;
while (l < r)
{
int mid = l + r + 1 >> 1;
if (up[mid] >= q[u]) l = mid;
else r = mid - 1;
}
// 注意这里是<= su,因为这里up[]从下标1开始用,y总版本k < su是因为up[]从下标0开始用
if (r + 1 <= su)
{
int t = up[r + 1];
up[r + 1] = q[u];
dfs(u + 1, su, sd);
up[r + 1] = t;
}
else
{
up[r + 1] = q[u];
dfs(u + 1, su + 1, sd);
}
l = 0, r = sd;
while (l < r)
{
int mid = l + r + 1 >> 1;
if (down[mid] <= q[u]) l = mid;
else r = mid - 1;
}
if (r + 1 <= sd)
{
int t = down[r + 1];
down[r + 1] = q[u];
dfs(u + 1, su, sd);
down[r + 1] = t;
}
else
{
down[r + 1] = q[u];
dfs(u + 1, su, sd + 1);
}
}
int main()
{
up[0] = 2e9, down[0] = -2e9;
while (scanf("%d", &n), n)
{
for (int i = 0; i < n; i++) scanf("%d", &q[i]);
res = n;
dfs(0, 0, 0);
printf("%d\n", res);
}
return 0;
}