Pagini recente » Cod sursa (job #2901489) | Cod sursa (job #1770953) | Cod sursa (job #1896028) | Cod sursa (job #1539435) | Cod sursa (job #2650355)
#include <cstdio>
#include <map>
using namespace std;
int v[50005];
int prevPos[50005];
int lastPos[50005];
int dp[50005];
map<int, int> c;
map<int, int> fr;
int main() {
freopen("secv.in", "r", stdin);
freopen("secv.out", "w", stdout);
int n;
scanf("%d", &n);
if (n == 1) {
printf("1");
return 0;
}
for (int i = 1; i <= n; ++i) {
scanf("%d", &v[i]);
}
for (int i = 1; i <= n; i++) {
if (fr[v[i]] == 0) {
c[v[i]]++;
fr[v[i]] = 1;
}
}
int pos = 0;
for (auto it : c) {
++pos;
fr[it.first] = pos;
}
for (int i = 1; i <= n; ++i) {
v[i] = fr[v[i]];
if (v[i] == 1) {
prevPos[i] = i;
} else
prevPos[i] = lastPos[v[i] - 1];
lastPos[v[i]] = i;
}
int minn = 1e9;
for (int i = 1; i <= n; ++i) {
if (prevPos[i]) {
dp[i] = dp[prevPos[i]] + i - prevPos[i];
} else
dp[i] = 1e9;
if (v[i] == c.size())
minn = min(minn, dp[i]);
}
if (minn == 1e9) {
printf("-1");
}
printf("%d", minn + 1);
return 0;
}