0

我的问题可能是重复的,但我真的觉得很难。(我已阅读相关主题)

这是数组:

Array
(
    [0] => Array
        (
            [legend] => 38440
        )

    [1] => Array
        (
            [bestw] => 9765
        )

    [2] => Array
        (
            [fiuna] => 38779
        )

    [3] => Array
        (
            [adam] => 39011
        )

    [4] => Array
        (
            [adam] => 39011
        )

    [5] => Array
        (
            [adam] => 39011
        )

)

我尝试了很多方法来处理这个数组并找出最常见的值。我期望的结果是“亚当”

$countwin = array_count_values($winnernames);
$maxwin = max($countwin);
$mostwinner = array_keys($countswin, $maxwin);

编辑:我的数组是这样array("A"=>"1" , "B"=>"2" , "A"=>"1") 的,它应该返回 A 是最常见的

4

2 回答 2

2

迭代你的数组并计算你得到的值怎么样?

$occurences = array();
foreach ($data as $row) {
  foreach ($row as $key => $score) {
    if (empty($occurences[$key])) {
      $occurences[$key] = 1;
    } else {
      $occurences[$key]++;
    }
  }
}

然后排序

arsort($occurences);

并获取排序数组的第一个元素

$t = array_keys($occurences);
$winner = array_shift($occurences);
于 2012-06-30T16:26:10.387 回答
-1

你可以试试这段代码。确实是蛮力的方法。但是快速搜索让我发现这是一个有用的:

function findDuplicates($data,$dupval) {
$nb= 0;
foreach($data as $key => $val)
if ($val==$dupval) $nb++;
return $nb;
}

编辑:对不起,我误解了你的问题!但这可能是找到最大计数器的第一个提示。

于 2012-06-30T16:19:17.083 回答