String Reorder

Back to Introductory Problems

Implementation

C++

                                #include<bits/stdc++.h>
using namespace std;
#define pii pair<int,int>
#define FASTIO ios_base::sync_with_stdio(false);cin.tie(NULL); cout.tie(NULL);
#define endl '\n'

string s;
bool check_possibility(int cur, int c, pair<int,int> mode) {
    int rem;
    int cnt;
    if(mode.second == c) {
        rem = s.size() - cur - 2;
        cnt = mode.first-1;
    } else {
        rem = s.size() - cur - 1;
        cnt = mode.first;
    }
    int req = (rem+1)/2;
    if ( cnt > req ) return false;
    return true;
}
void solve() {
    cin>>s; 
    string res = "";
    int n = s.size();
    int freq[26] = {0};
    for(auto c:s) freq[c-'A']++;
    for(int i=0;i<n;i++) {

        pair<int,int> mode = {-1,0};
        pair<int,int> mode_2 = {-1,0};
        for(int j=0;j<26;j++) {
            if(freq[j] == 0) continue;
            if ( make_pair(freq[j], j) > mode ) {
                mode_2 = mode;
                mode = {freq[j],j};
            } else if ( make_pair(freq[j], j) > mode_2 ) {
                mode_2 = {freq[j],j};
            } 
        }

        bool possible = false;
        for(int j=0;j<26;j++) {
            if(freq[j] == 0 or (res.size()!=0 and res.back() == j+'A')) continue;
            // cout<<"checking for "<<(char)(j+'A')<<endl;
            if( !check_possibility(i,j,mode) or !check_possibility(i,j, mode_2) ) continue;
            possible = true;
            res += 'A'+j;
            freq[j]--;
            break;
        }
        if(!possible) {
            cout<<-1;
            return;
        }
    }
    cout<<res;
}

signed main() {
    //FASTIO;
    int tc = 1;
    // cin>>tc;

    for(int i=1;i<=tc;i++) {
        solve();
    }
}