Pagini recente » Cod sursa (job #2457994) | Cod sursa (job #2446862) | Cod sursa (job #2446857) | Cod sursa (job #2142203) | Cod sursa (job #2191930)
#include <iostream>
#include <fstream>
#include <climits>
using namespace std;
ifstream f("scmax.in");
ofstream g("scmax.out");
int x[100010], k[100010], pz[100010], nr;
int maxi(int poz)
{
int mx = INT_MIN;
for (int i = 1; i <= poz; i++)
if (k[i] > mx && x[i] < x[poz + 1])
mx = k[i];
return mx;
}
int main()
{
int n, maX, actual, mx = INT_MIN;
f>>n;
for (int i = 1; i <= n; i++)
f>>x[i];
for (int i = 1; i <= n; i++)
{
maX = maxi(i - 1);
k[i] = max(maX + 1, k[i]);
if (k[i] > mx)
mx = k[i];
}
g<<mx + 1<<'\n';
for (int i = 1; i <= n; i++)
g<<k[i]<<" ";
return 0;
}