トップページに戻る
次の競技プログラミングの問題へ
前の競技プログラミングの問題へ
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());
}
}
解説
数字で構成される文字列として、降順にソートしてます。