Pagini recente » Cod sursa (job #92410) | Cod sursa (job #2232902) | Cod sursa (job #3236796) | Borderou de evaluare (job #1888963) | Cod sursa (job #2320338)
#include <bits/stdc++.h>
using namespace std;
ifstream f ("ordine.in");
ofstream g ("ordine.out");
int n,fr[27],i,j,ok;
char c[1000001],v[1000001],b;
int main()
{
f>>c;
n=strlen(c);
for(i=0; i<n; i++)
fr[(int)c[i]-97]++;
for(i=0; i<n; i++)
{
ok=1;
for(j=0; j<=26; j++)
{
if(fr[j]==(n-i)/2+1)
{
v[i]=(char)(97+j);
fr[j]--;
ok=0;
}
}
for(j=0; j<=26 && ok==1; j++)
{
if(fr[j])
{
b=(char)(97+j);
if(b!=v[i-1])
{
v[i]=b;
fr[j]--;
ok=0;
}
}
}
}
g<<v;
return 0;
}