基于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兩列原來(lái)的數(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ù)組中排序與自身原來(lái)一致)
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
CodeIgniter基于Email類(lèi)發(fā)郵件的方法
這篇文章主要介紹了CodeIgniter基于Email類(lèi)發(fā)郵件的方法,結(jié)合實(shí)例形式分析了CodeIgniter調(diào)用CI自帶的Email類(lèi)實(shí)現(xiàn)發(fā)送郵件的相關(guān)使用技巧,需要的朋友可以參考下2016-03-03
Laravel 的數(shù)據(jù)庫(kù)遷移的方法
本篇文章主要介紹了Laravel 的數(shù)據(jù)庫(kù)遷移的方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-07-07
免費(fèi)手機(jī)號(hào)碼歸屬地API查詢(xún)接口和PHP使用實(shí)例分享
最近在做全國(guó)性的行業(yè)分類(lèi)信息網(wǎng)站,需要用到手機(jī)號(hào)歸屬地顯示功能,于是就穿梭于各大權(quán)威站點(diǎn)之間偷來(lái)了API的接口地址。 分享出來(lái),大家可以用到就拿去呵2014-04-04
tp5(thinkPHP5)框架實(shí)現(xiàn)多數(shù)據(jù)庫(kù)查詢(xún)的方法
這篇文章主要介紹了tp5(thinkPHP5)框架實(shí)現(xiàn)多數(shù)據(jù)庫(kù)查詢(xún)的方法,結(jié)合實(shí)例形式分析了thinkPHP5框架多數(shù)據(jù)庫(kù)查詢(xún)的相關(guān)配置、初始化及調(diào)用相關(guān)操作技巧,需要的朋友可以參考下2019-01-01

