php shuffle() 可能會(huì)生成相鄰重復(fù)元素。為了避免這種情況,可以使用以下兩種方法:使用 a-hash 算法:為每個(gè)值生成哈希,僅保留唯一的哈希值對應(yīng)的值。使用標(biāo)記和洗牌:標(biāo)記已使用的索引,在洗牌前刪除標(biāo)記的索引值。
PHP 數(shù)組打亂順序時(shí)避免相鄰重復(fù)元素
在 PHP 中,使用 shuffle()
函數(shù)打亂數(shù)組順序是一種常見的需求。然而,這個(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ù)組。