General
 
 
# Author Problem Lang Verdict Time Memory Sent Judged  
122823876 Contestant:
sansen
1530E - 12 Rust Accepted 61 ms 6984 KB 2021-07-17 18:59:08 2021-07-17 21:32:40
 
 
→ Source
// ---------- begin input macro ----------
// reference: https://qiita.com/tanakh/items/0ba42c7ca36cd29d0ac8
macro_rules! input {
    (source = $s:expr, $($r:tt)*) => {
        let mut iter = $s.split_whitespace();
        input_inner!{iter, $($r)*}
    };
    ($($r:tt)*) => {
        let s = {
            use std::io::Read;
            let mut s = String::new();
            std::io::stdin().read_to_string(&mut s).unwrap();
            s
        };
        let mut iter = s.split_whitespace();
        input_inner!{iter, $($r)*}
    };
}

macro_rules! input_inner {
    ($iter:expr) => {};
    ($iter:expr, ) => {};
    ($iter:expr, $var:ident : $t:tt $($r:tt)*) => {
        let $var = read_value!($iter, $t);
        input_inner!{$iter $($r)*}
    };
}

macro_rules! read_value {
    ($iter:expr, ( $($t:tt),* )) => {
        ( $(read_value!($iter, $t)),* )
    };
    ($iter:expr, [ $t:tt ; $len:expr ]) => {
        (0..$len).map(|_| read_value!($iter, $t)).collect::<Vec<_>>()
    };
    ($iter:expr, chars) => {
        read_value!($iter, String).chars().collect::<Vec<char>>()
    };
    ($iter:expr, bytes) => {
        read_value!($iter, String).bytes().collect::<Vec<u8>>()
    };
    ($iter:expr, usize1) => {
        read_value!($iter, usize) - 1
    };
    ($iter:expr, $t:ty) => {
        $iter.next().unwrap().parse::<$t>().expect("Parse error")
    };
}
// ---------- end input macro ----------

use std::io::Write;
use std::collections::*;

type Map<K, V> = BTreeMap<K, V>;
type Set<T> = BTreeSet<T>;
type Deque<T> = VecDeque<T>;

// ある文字が1個しかないならそれを先頭に持っていって後は自由
// どれも2個以上
// fは1以上となる
//
// いや、辞書順最小の条件は?
// fを0にできる時、先頭の文字は1個の文字で最小のやつ
// それより小さい文字をとってくるとfが1になる
// 2文字目以降はソートでOK
// 
// fを最小化することに注力
// f=1にできるか
// 2文字しかないやつがあるならできる
// それ以外
// サンプル2がそうでない例
// ざっくり半分以下の文字をa、それ以外をbとして
// aabababab...abbbbbbbb
// はf=1を達成する
// 過半数の文字で1を達成することはできないか?
// abaaaaaaaaaaaaa...ab
// とかで2になる?
// abaaa....aaacb...
// なら1でいい
// 一番小さい文字を先頭にできるかが鍵
// aが半分以下なら
// aabababab... でf=1達成
// これが最小?
// どこかしらのbをaにするとf=2になるので最小
// a が半数超えてるなら?
// 文字が3種あるなら
// abaaaaaaaaaaaa...ac...
// でいい
// 最小?
// aaaはダメ
// aababab..abaca
// とかはいける
// 半数より1多い?
// (n-2)/2+2までならいける
// 2種ならbaaaaa.....aabbbbb
// でいい
// 
//
// まとめよう
// 種類数が1ならそのまま
// 頻度が1のものがあるならそれを先頭にしてあとはソート
// 一番小さい文字について
// 頻度が(n-2)/2+2以下なら
// aabab...abbb...
// でいい
// 頻度が多い場合
// 種類数が3以上なら
// aba....acbb...bcc...
// でいい
// そうでないなら
// baa.....aabb.....
// いずれもf=1となる
// 
// WA
// もっと小さい文字列?
// 種類数1はどうしようもない
// 頻度1?
// f=0, それ以外にf=0にする方法はない
// 小さい文字について
// 頻度がkとして
// k - 2 <= n - k なら
// aabab...ababbbbb...
// でf=1
// 先頭以外でaを連続させたら死ぬ
// aaは確定している
// 次はa以外
// ...
// 正しいはず
// k - 2 > n - k
// の時?
// aa.. とするとどこかでaが連続してしまう
// ab が欲しい
// abaaaa....aaaaa cb....
// が解じゃないか?
// 正しそうな
// 種類数が2の時
// baa...aabb.. としたが先頭aにできないのか?
// abb...bbaaaでいける...

fn run() {
    input! {
        t: usize,
        ask: [chars; t],
    }
    let out = std::io::stdout();
    let mut out = std::io::BufWriter::new(out.lock());
    for s in ask {
        let n = s.len();
        let mut map = Map::new();
        for s in s {
            *map.entry(s).or_insert(0) += 1;
        }
        let mut p = map.into_iter().collect::<Vec<_>>();
        if p.len() == 1 {
            let s = (0..n).map(|_| p[0].0).collect::<String>();
            writeln!(out, "{}", s).ok();
            continue;
        }
        if let Some(x) = p.iter().position(|p| p.1 == 1) {
            let mut ans = String::new();
            ans.push(p[x].0);
            p[x].1 -= 1;
            for (c, p) in p {
                for _ in 0..p {
                    ans.push(c);
                }
            }
            writeln!(out, "{}", ans).ok();
            continue;
        }
        let cnt = p[0].1;
        p[0].1 = 0;
        if cnt - 2 <= n - cnt {
            let mut ans = String::new();
            ans.push(p[0].0);
            ans.push(p[0].0);
            for _ in 2..cnt {
                let x = p.iter().position(|p| p.1 > 0).unwrap();
                ans.push(p[x].0);
                p[x].1 -= 1;
                ans.push(p[0].0);
            }
            while let Some(x) = p.iter().position(|p| p.1 > 0) {
                ans.push(p[x].0);
                p[x].1 -= 1;
            }
            writeln!(out, "{}", ans).ok();
            continue;
        }
        if p.len() > 2 {
            let mut ans = String::new();
            ans.push(p[0].0);
            ans.push(p[1].0);
            p[1].1 -= 1;
            for _ in 1..cnt {
                ans.push(p[0].0);
            }
            ans.push(p[2].0);
            p[2].1 -= 1;
            while let Some(x) = p.iter().position(|p| p.1 > 0) {
                ans.push(p[x].0);
                p[x].1 -= 1;
            }
            writeln!(out, "{}", ans).ok();
            continue;
        }
        let mut ans = String::new();
        ans.push(p[0].0);
        for _ in 0..p[1].1 {
            ans.push(p[1].0);
        }
        for _ in 1..cnt {
            ans.push(p[0].0);
        }
        writeln!(out, "{}", ans).ok();
    }
}

fn main() {
    run();
}
 
 
?
Time: ? ms, memory: ? KB
Verdict: ?
Input
?
Participant's output
?
Jury's answer
?
Checker comment
?
Diagnostics
?
Click to see test details