Pagini recente » Cod sursa (job #456723) | Cod sursa (job #1412156) | Cod sursa (job #2502087) | Cod sursa (job #1500211) | Cod sursa (job #121209)
Cod sursa(job #121209)
#include<stdio.h>
#include<iostream.h>
/// -97
long v[26],n,i,poz=-1,gasit=-9; char s;
int cauta()
{long aux=(n-i)/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); v[s-97]++; n++;} n--;;
for(i=0;i<n;i++)
printf("%c",cauta()+97);
printf("\n");
}