1. ホーム
  2. php

[解決済み] PHP で配列の中央値を計算する

2022-02-16 08:30:28

質問

ランダムに生成された数値の配列の中央値を計算する方法を考えています。配列はすべてセットアップされていますが、計算のための関数を組み立てるのに苦労しています。

今のところ、こんな感じです。

//array 
$lessFifty = array();
$moreFifty = array();

//number generation
for ($i = 0; $i<=30; $i++) {
      $number = rand(0, 100);

//Sorting <50>      
if ($number < 50 ) {
    $lessFifty[] = $number;
} else {
    $moreFifty[] = $number; 
   } 
}
 echo print_r($lessFifty); 
 echo "<br>" ;
 echo print_r($moreFifty);

   //Average
echo "<p> Average of values less than fifty: </p>";
    print   array_sum($lessFifty) / count($lessFifty) ;
echo "<p> Average of values greater than fifty: </p>" ;  
    print   array_sum($moreFifty) / count($moreFifty) ;

//Median
$func = function (median ($array, $output = $median)){ 
    if(!is_array($array)){
        return FALSE;
    }else{
        switch($output){
                rsort($array);
                $middle = round(count($array) 2);
    $total = $array[$middle-1];
        break; 
    return $total;
    }
}

echo $func ; 

この中央分離帯の部分は、完全に間違っていると思います。私はまだ勉強中で、それが課題であることを証明している。

どのように解決するのですか?

の書き方に注意しましょう。 for() ループを使用します。 もし、30個のエントリーをしたいのであれば <= のため、31になってしまいます。 $i は0から始まります。

乱数の配列を構築し、ソートする。

そして、中央のエントリーがあるか(配列の長さが奇数)、真ん中の2つのエントリーを平均化する必要があるか(配列の長さが偶数)を判断します。

コード ( デモ )

$limit = 30;  // how many random numbers do you want?  30 or 31?
for ($i = 0; $i < $limit; ++$i) {
    $numbers[] = rand(0, 100);
}
var_export($numbers);

//echo "\n---\nAverage: " , array_sum($numbers) / $limit;
echo "\n---\n";

sort($numbers);
$count = sizeof($numbers);   // cache the count
$index = floor($count/2);  // cache the index
if (!$count) {
    echo "no values";
} elseif ($count & 1) {    // count is odd
    echo $numbers[$index];
} else {                   // count is even
    echo ($numbers[$index-1] + $numbers[$index]) / 2;
}

可能な出力

array (
  0 => 27,
  1 => 24,
  2 => 84,
  3 => 43,
  4 => 8,
  5 => 51,
  6 => 60,
  7 => 86,
  8 => 9,
  9 => 48,
  10 => 67,
  11 => 20,
  12 => 44,
  13 => 85,
  14 => 6,
  15 => 63,
  16 => 41,
  17 => 32,
  18 => 64,
  19 => 73,
  20 => 43,
  21 => 24,
  22 => 15,
  23 => 19,
  24 => 9,
  25 => 93,
  26 => 88,
  27 => 77,
  28 => 11,
  29 => 54,
)
---
43.5

ソート後、要素 [14][15] ホールド 4344 をそれぞれ作成します。 この真ん中の2つの値の平均が、結果の判定になります。 ( ハードコードされた数値のデモ )


もし、短くて柔軟性のないハードコードされたスニペットが欲しいのであれば 301415 を所定のサイズとインデックスに設定してください。

for ($i = 0; $i < 30; ++$i) {
    $numbers[] = rand(0, 100);
}
sort($numbers);
echo ($numbers[14] + $numbers[15]) / 2;