Pagini recente » Cod sursa (job #2271783) | Cod sursa (job #2750351) | Cod sursa (job #369611) | Cod sursa (job #878402) | Cod sursa (job #902841)
Cod sursa(job #902841)
#include <cstdio>
using namespace std;
FILE *fi=fopen("ordine.in","r");
FILE *g=fopen("ordine.out","w");
char s[1000005],ant=-1;
int size,f[30];
int main()
{
fgets(s,1000005,fi);
for(int i=0;s[i];i++,size++)
++f[s[i]-'a'];
for(int i=1;i<=size;i++)
{
int c=-1;
for(int j=0;j<26;j++)
if(ant!=j && f[j]==(size-i+1)/2+1)
{
c=j;
break;
}
if(c!=-1)
{
fprintf(g,"%c",char(c + 'a'));
--f[c];
ant=c;
}
else
for(int j=0;j<26;j++)
if(ant!=j && f[j])
{
fprintf(g,"%c",char(j+'a'));
f[j]--;
ant=j;
break;
}
}
return 0;
}