Cod sursa(job #902841)

Utilizator superman_01Avramescu Cristian superman_01 Data 1 martie 2013 16:57:26
Problema Ordine Scor 0
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.85 kb
#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;
}