トップページに戻る
次の競技プログラミングの問題へ
前の競技プログラミングの問題へ
No.275 中央値を求めよ
■■■問題■■■
N個の数値Aiが与えられるので、その中央値(メジアン)を求めてください。
中央値(メジアン)とは、小さい順に並べたとき中央に位置する値。
データが偶数個の場合は、中央に近い2つの値の算術平均をとる。
小数第一位まで求めてください。
(数値が正しければ、余計な小数桁が含まれてても良い)
■■■入力■■■
N
A1 A2 ・・・ AN
入力は全て整数で与えられる。
●1 <= N <= 1000
●-1000 <= Ai <= 1000
■■■出力■■■
配列の中央値を求めてください。
最後に改行してください。
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("3");
WillReturn.Add("5 3 4");
//4
//この場合の中央値は4です。
//4.00のような出力でも良い。
}
else if (InputPattern == "Input2") {
WillReturn.Add("4");
WillReturn.Add("1 9 8 4");
//6
//この場合は(8+4)/2=6です。
}
else if (InputPattern == "Input3") {
WillReturn.Add("6");
WillReturn.Add("1 2 3 4 5 6");
//3.5
//この場合の答えは小数になります。
}
else {
string wkStr;
while ((wkStr = Console.ReadLine()) != null) WillReturn.Add(wkStr);
}
return WillReturn;
}
static void Main()
{
List<string> InputList = GetInputList();
int[] AArr = InputList[1].Split(' ').Select(X => int.Parse(X)).ToArray();
Array.Sort(AArr);
int wkLen=AArr.Length;
if (wkLen % 2 == 0) {
decimal Answer = AArr[wkLen / 2];
Answer += AArr[wkLen / 2-1];
Console.WriteLine(Answer / 2);
}
else {
Console.WriteLine(AArr[wkLen / 2]);
}
}
}
解説
要素数が偶数か奇数かで場合に分けてます。