基于php實現(xiàn)隨機合并數(shù)組并排序(原排序)
最近做了一個項目,其中有這樣一個需求要實現(xiàn),原有帖子列表A,現(xiàn)在需要在A中推廣新業(yè)務(wù)B,那么需要在A列表中1:1混合B中的數(shù)據(jù),隨機混合,但是需要保持A和B兩列原來的數(shù)據(jù)排序,具體詳情請看下文。
原理
獲知總共元素數(shù)量N;
for循環(huán)N次,取隨機數(shù);
根據(jù)隨機數(shù)依次從頭獲取A或B的值,推入新數(shù)組中;
代碼:
//隨機合并兩個數(shù)組元素,保持原有數(shù)據(jù)的排序不變(即各個數(shù)組的元素在合并后的數(shù)組中排序與自身原來一致) 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; }
示例:
合并前的數(shù)組:
$array1 = array(1, 2, 3, 4); $array2 = array('a', 'b', 'c', 'd', 'e');
合并后的數(shù)據(jù):
$mergeArray = array ( 0 => 'a', 1 => 1, 2 => 'b', 3 => 2, 4 => 'c', 5 => 'd', 6 => 3, 7 => 4, 8 => 'e', )
php數(shù)組隨機排序
<?php $array = array('A','2','3','4','5','6','7','8','9','10','J','Q','K'); shuffle($array); //隨機排序數(shù)組 print_r($array); //輸出數(shù)組 ?>
相關(guān)文章
php array_merge_recursive 數(shù)組合并
這篇文章主要介紹了php array_merge_recursive 將兩個或多個數(shù)組合并為一個數(shù)組的相關(guān)資料,需要的朋友可以參考下2016-10-10tp5(thinkPHP5)框架實現(xiàn)多數(shù)據(jù)庫查詢的方法
這篇文章主要介紹了tp5(thinkPHP5)框架實現(xiàn)多數(shù)據(jù)庫查詢的方法,結(jié)合實例形式分析了thinkPHP5框架多數(shù)據(jù)庫查詢的相關(guān)配置、初始化及調(diào)用相關(guān)操作技巧,需要的朋友可以參考下2019-01-01