トップページに戻る    次の競技プログラミングの問題へ    前の競技プログラミングの問題へ

No.256 桁の数字を入れ替え (2)

■■■問題■■■

2桁以上10万桁以下の正整数Nが与えられます。
好きな回数だけ、2つの桁の数字を選び入れ替えることができます。
1回も入れ替えないということも許されます。
最も大きな整数を作ろうとしたとき、その最も大きな整数はいくつか?

Nは32ビット整数型では扱えない数になることがあることに注意。

■■■入力■■■

N

1 <= N <= 10の9999乗

■■■出力■■■

最も大きな整数を出力せよ。


C#のソース

using System;
using System.Collections.Generic;
using System.Linq;

class Program
{
    static string InputPattern = "Input1";

    static List<string> GetInputList()
    {
        var WillReturn = new List<string>();

        if (InputPattern == "Input1") {
            WillReturn.Add("12");
            //21
        }
        else if (InputPattern == "Input2") {
            WillReturn.Add("21");
            //21
        }
        else if (InputPattern == "Input3") {
            WillReturn.Add("1122");
            //2211
            //No.39と違い、2回入れ替えることが許されることに注意せよ
        }
        else {
            string wkStr;
            while ((wkStr = Console.ReadLine()) != null) WillReturn.Add(wkStr);
        }
        return WillReturn;
    }

    static void Main()
    {
        List<string> InputList = GetInputList();
        string NStr = InputList[0];

        char[] StrArr = NStr.ToCharArray();
        Array.Sort(StrArr, (A, B) => B.CompareTo(A));

        var sb = new System.Text.StringBuilder();
        Array.ForEach(StrArr, X => sb.Append(X));
        Console.WriteLine(sb.ToString());
    }
}


解説

数字で構成される文字列として、降順にソートしてます。