Pagini recente » Cod sursa (job #2843781) | Cod sursa (job #805857) | Cod sursa (job #1479515) | Cod sursa (job #2629731) | Cod sursa (job #121216)
Cod sursa(job #121216)
#include<stdio.h>
#include<iostream.h>
/// -97
long v[27],n,j,poz=-1,gasit=-9; char s;
int cauta()
{long aux=(n-j+1)/2+1;
int i;
if(gasit!=poz && gasit!=-9) {v[gasit]--; return poz=gasit;}
for(i=0;i<poz;i++)
if(v[i]==aux && gasit==-9) {v[i]--; gasit=i; return poz=i;}
else
if(v[i]>0) {v[i]--; return poz=i;}
for(i=poz+1;i<=25;i++)
if(v[i]==aux && gasit==-9) {v[i]--; gasit=i; return poz=i;}
else
if(v[i]>0) {v[i]--; return poz=i;}
}
main()
{freopen("ordine.in","r",stdin);
freopen("ordine.out","w",stdout);
while(!feof(stdin)) {s=fgetc(stdin); if(s-97>0) v[s-97]++; n++;} n--;
for(j=1;j<=n;j++)
printf("%c",cauta()+97);
printf("\n");
}