Cod sursa(job #2296121)

Utilizator rares404AlShaytan - Balasescu Rares rares404 Data 4 decembrie 2018 13:53:26
Problema Ordine Scor 70
Compilator cpp-64 Status done
Runda Arhiva de probleme Marime 0.73 kb
#include <bits/stdc++.h>

std::ifstream in ("ordine.in") ;
std::ofstream out ("ordine.out") ;

std::string s ;
std::map <char, int> mp ;
int main(){
    in >> s ;
    int len(s.size()) ;
    register int i ;
    register char j ;
    char Ans, Previous(0) ;
    for (i = 0 ; i < len ; ++ i) {
        mp[s[i]] ++ ;
    }
    bool Good ;
    for (i = 0 ; i < len ; ++ i) {
        Good = true ;
        for (j = 'a' ; j <= 'z' ; ++ j) {
            if ((mp[j] > 0 && j != Previous && Good == true) || (mp[j] >= (len - i) / 2 + 1 && j != Previous)) {
                Ans = j ;
                Good = false ;
            }
        }
        mp[Ans] -- ;
        Previous = Ans ;
        out << Ans ;
    }
    return 0;
}