Pagini recente » Cod sursa (job #1740514) | Cod sursa (job #1755101) | Cod sursa (job #799068) | Cod sursa (job #410938) | Cod sursa (job #1981484)
#include <fstream>
#include <algorithm>
using namespace std;
ifstream f ("partitie.in");
ofstream g ("partitie.out");
int n,d,i,j,sol,v[1000000],p[1000000];
bool srt(int x,int y)
{
return v[x]<v[y];
}
int main()
{
f>>n>>d;
for(i=1;i<=n;++i)
f>>v[i];
p[i]=i;
sort(p+1,p+n+1,srt);
for(i=j=1;i<=n;++i)
{
for(;j<=n&&v[p[i]]-v[p[j]]>=d;++j);
sol=max(sol,i-j+1);
}
g<<sol<<'\n';
for(i=1;i<=n;++i) v[p[i]]=i%sol+1;
for(i=1;i<=n;++i) g<<v[i]<<'\n';
}