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

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]);
        }
    }
}


解説

要素数が偶数か奇数かで場合に分けてます。