基于php實(shí)現(xiàn)隨機(jī)合并數(shù)組并排序(原排序)
最近做了一個(gè)項(xiàng)目,其中有這樣一個(gè)需求要實(shí)現(xiàn),原有帖子列表A,現(xiàn)在需要在A中推廣新業(yè)務(wù)B,那么需要在A列表中1:1混合B中的數(shù)據(jù),隨機(jī)混合,但是需要保持A和B兩列原來的數(shù)據(jù)排序,具體詳情請(qǐng)看下文。
原理
獲知總共元素?cái)?shù)量N;
for循環(huán)N次,取隨機(jī)數(shù);
根據(jù)隨機(jī)數(shù)依次從頭獲取A或B的值,推入新數(shù)組中;
代碼:
//隨機(jī)合并兩個(gè)數(shù)組元素,保持原有數(shù)據(jù)的排序不變(即各個(gè)數(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ù)組隨機(jī)排序
<?php $array = array('A','2','3','4','5','6','7','8','9','10','J','Q','K'); shuffle($array); //隨機(jī)排序數(shù)組 print_r($array); //輸出數(shù)組 ?>
相關(guān)文章
php array_merge_recursive 數(shù)組合并
這篇文章主要介紹了php array_merge_recursive 將兩個(gè)或多個(gè)數(shù)組合并為一個(gè)數(shù)組的相關(guān)資料,需要的朋友可以參考下2016-10-10免費(fèi)手機(jī)號(hào)碼歸屬地API查詢接口和PHP使用實(shí)例分享
最近在做全國性的行業(yè)分類信息網(wǎng)站,需要用到手機(jī)號(hào)歸屬地顯示功能,于是就穿梭于各大權(quán)威站點(diǎn)之間偷來了API的接口地址。 分享出來,大家可以用到就拿去呵2014-04-04tp5(thinkPHP5)框架實(shí)現(xiàn)多數(shù)據(jù)庫查詢的方法
這篇文章主要介紹了tp5(thinkPHP5)框架實(shí)現(xiàn)多數(shù)據(jù)庫查詢的方法,結(jié)合實(shí)例形式分析了thinkPHP5框架多數(shù)據(jù)庫查詢的相關(guān)配置、初始化及調(diào)用相關(guān)操作技巧,需要的朋友可以參考下2019-01-01