php shuffle() 可能會(huì)生成相鄰重復(fù)元素。為了避免這種情況,可以使用以下兩種方法:使用 a-hash 算法:為每個(gè)值生成哈希,僅保留唯一的哈希值對(duì)應(yīng)的值。使用標(biāo)記和洗牌:標(biāo)記已使用的索引,在洗牌前刪除標(biāo)記的索引值。
PHP 數(shù)組打亂順序時(shí)避免相鄰重復(fù)元素
在 PHP 中,使用 shuffle() 函數(shù)打亂數(shù)組順序是一種常見(jiàn)的需求。然而,這個(gè)函數(shù)可能會(huì)生成相鄰的重復(fù)元素。為了避免這種情況,我們可以使用以下方法:
實(shí)現(xiàn):
- 使用 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;
}
登錄后復(fù)制
- 使用標(biāo)記和洗牌:
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;
}
登錄后復(fù)制
實(shí)戰(zhàn)案例:
$array = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]; $shuffled_array = shuffle_array_avoid_adjacent_duplicates($array); print_r($shuffled_array);
登錄后復(fù)制
輸出:
Array
(
[0] => 5
[1] => 2
[2] => 9
[3] => 10
[4] => 7
[5] => 4
[6] => 3
[7] => 8
[8] => 6
[9] => 1
)
登錄后復(fù)制
以上代碼使用 a-Hash 算法避免了相鄰重復(fù)元素,生成了打亂順序的數(shù)組。






