天天看點

php 數組随機排序_基于php實作随機合并數組并排序(原排序)

最近做了一個項目,其中有這樣一個需求要實作,原有文章清單A,現在需要在A中推廣新業務B,那麼需要在A清單中1:1混合B中的資料,随機混合,但是需要保持A和B兩列原來的資料排序,具體詳情請看下文。

原理

獲知總共元素數量N;

for循環N次,取随機數;

根據随機數依次從頭擷取A或B的值,推入新數組中;

代碼:

//随機合并兩個數組元素,保持原有資料的排序不變(即各個數組的元素在合并後的數組中排序與自身原來一緻)

function shuffleMergeArray() {

$mergeArray = array();

$sum = count($array1) + count($array2);

for ($k = $sum; $k > 0; $k--) {

$number = mt_rand(1, 2);

if ($number == 1) {

$mergeArray[] = $array2 ? array_shift($array2) : array_shift($array1);

} else {

$mergeArray[] = $array1 ? array_shift($array1) : array_shift($array2);

}

}

return $mergeArray;

}

示例:

合并前的數組:

$array1 = array(1, 2, 3, 4);

$array2 = array('a', 'b', 'c', 'd', 'e');

合并後的資料:

$mergeArray = array (

0 => 'a',

1 => 1,

2 => 'b',

3 => 2,

4 => 'c',

5 => 'd',

6 => 3,

7 => 4,

8 => 'e',

)

php數組随機排序

$array = array('A','2','3','4','5','6','7','8','9','10','J','Q','K');

shuffle($array); //随機排序數組

print_r($array); //輸出數組

?>