所以我有一个包含球员姓名和技能水平的数据库。
它看起来像这样:
Id | Name | Level
1 | Peter | 24
2 | Andy | 23
...
24 | John | 1
列表中等级最高的第一个玩家是最强的,最后一个是最弱的。
我需要将他们分为 4 名玩家的组,所以如果我有 24 人,则将有 6 组。
我需要对它进行排序的方式称为“之字形”。
事情是这样的:
Ag Bg Cg Dg Eg Fg
01 02 03 04 05 06
12 11 10 09 08 07
13 14 15 16 17 18
24 23 22 21 20 19
因此 A 组将由以下球员组成:1、12、13、24.
B组选手:2、11、14、23.
C组选手:3、10、15、22等等。
手动完成很容易,但是如何使用 PHP 语言自动完成这种排序呢?
这些组应该是数组列表(我认为是这样),我可以轻松地将其放入数据库中的组表中。
这个想法是:
- 对起始数据进行排序(或者最好从排序开始)。
- 将其分成几块,基本上每一行都有一个。
- 反转所有其他块的顺序。
- 翻转矩阵,这样你就得到了你的组——每列一个而不是每行一个。
Example:
// Basic sample data.
$players = range(1, 24);
// Sort them ascending if you need to.
sort($players);
// Make a matrix. 2d array with a column per group.
$matrix = array_chunk($players, ceil(count($players)/4));
// Reverse every other row.
for ($i = 0; $i < count($matrix); $i++) {
if ($i % 2) {
$matrix[$i] = array_reverse($matrix[$i]);
}
}
// Flip the matrix.
$groups = array_map(null, ...$matrix); // PHP 5.6 with the fancy splat operator.
//$groups = call_user_func_array('array_map', array_merge([null], $matrix)); // PHP < 5.6 - less fancy.
// The result is...
print_r($groups);
Output:
Array
(
[0] => Array
(
[0] => 1
[1] => 12
[2] => 13
[3] => 24
)
[1] => Array
(
[0] => 2
[1] => 11
[2] => 14
[3] => 23
)
[2] => Array
(
[0] => 3
[1] => 10
[2] => 15
[3] => 22
)
[3] => Array
(
[0] => 4
[1] => 9
[2] => 16
[3] => 21
)
[4] => Array
(
[0] => 5
[1] => 8
[2] => 17
[3] => 20
)
[5] => Array
(
[0] => 6
[1] => 7
[2] => 18
[3] => 19
)
)
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)