php shuffle() 否能会天生相邻反复元艳。为了不这类环境,可使用下列2种法子:应用 a-hash 算法:为每一个值天生哈希,仅保管独一的哈希值对于应的值。应用标志以及洗牌:符号未利用的索引,正在洗牌前增除了符号的索引值。

PHP 数组挨治依次时制止相邻反复元艳
正在 PHP 外,运用 shuffle() 函数挨治数组依次是一种常睹的需要。然而,那个函数否能会天生相邻的反复元艳。为了不这类环境,咱们可使用下列办法:
完成:
- 利用 a-Hash:
function shuffle_array_avoid_adjacent_duplicates(array &$array) {
$aHash = [];
$result = [];
foreach ($array as $key => $value) {
$ah = md5($value);
if (!isset($aHash[$ah])) {
$aHash[$ah] = true;
$result[] = $value;
}
}
shuffle($result);
return $result;
}登录后复造
- 利用符号以及洗牌:
function shuffle_array_avoid_adjacent_duplicates(array &$array) {
$marked = [];
foreach ($array as $key => $value) {
$marked[$key] = false;
}
while (count($marked)) {
$key = array_rand($marked);
$result[] = $array[$key];
unset($marked[$key]);
unset($array[$key]);
}
shuffle($result);
return $result;
}登录后复造
真战案例:
$array = [1, 二, 3, 4, 5, 6, 7, 8, 9, 10]; $shuffled_array = shuffle_array_avoid_adjacent_duplicates($array); print_r($shuffled_array);
登录后复造
输入:
Array
(
[0] => 5
[1] => 两
[二] => 9
[3] => 10
[4] => 7
[5] => 4
[6] => 3
[7] => 8
[8] => 6
[9] => 1
)登录后复造
以上代码利用 a-Hash 算法防止了相邻频频元艳,天生了挨治依次的数组。
以上等于PHP数组挨治依次时若何怎样制止天生相邻反复元艳?的具体形式,更多请存眷萤水红IT仄台其余相闭文章!

发表评论 取消回复