Pagini recente » Cod sursa (job #412468) | Cod sursa (job #802336) | Cod sursa (job #2198969) | Cod sursa (job #466580) | Cod sursa (job #485575)
Cod sursa(job #485575)
#include<cstdio>
const int N=1000002;
char s[N];
int nr,fr[N];
void citire()
{
gets(s);
for (int i=0;s[i];++i)
if (s[i]>='a' && s[i]<='z')
{
nr=i;
fr[(int)s[i]-(int)'a']++;
}
}
void rez()
{
char last,x;
for (int j=0;j<26;++j)
if (fr[j])
{
fr[j]--;
last=(char)97+j;
printf("%c",last);
break;
}
int j,k;
for (int i=1;i<=nr;++i)
{
j=0;
while (fr[j]==0)
j++;
x=(char)97+j;
if (x!=last)
{
last=x;
fr[j]--;
printf("%c",last);
}
else
{
k=j+1;
while (fr[k]==0)
++k;
last=(char)97+k;
fr[k]--;
printf("%c",last);
}
}
}
int main()
{
freopen("ordine.in","r",stdin);
freopen("ordine.out","w",stdout);
citire();
rez();
return 0;
}