gpt4 book ai didi

php array shuffle/randomize array 所以没有两个相等的值不接近

转载 作者:搜寻专家 更新时间:2023-10-31 21:53:38 24 4
gpt4 key购买 nike

所以我有一个数组 [ A,A,B,B,B,C,C,C,C,C ] 我需要以某种方式洗牌/随机化,它会随机排序项目,但尽可能将相同的值分开。最好的结果是 [ C,A,B,C,A,B,C,B,C,C ]

到目前为止我的代码:

<?php

$UnitedList = [
'A',
'A',
'B',
'B',
'B',
'C',
'C',
'C',
'C',
'C'
];

$mixed_list = [];
$i = 0;

function getKey(&$array, $not) {
$rk = array_rand($array);
// echo $rk;
if ($array[$rk] !== $not || count(array_unique($array)) === 1) {
return $rk;
}

return getKey($array, $not);
}

while (!empty($UnitedList)) {
$randomk = array_rand($UnitedList);

if ( $i === 0 ) {
$mixed_list[] = $UnitedList[$randomk];
unset($UnitedList[$randomk]);
++$i;
continue;
}

if (isset($mixed_list[$i - 1]) && $mixed_list[$i - 1] !== $UnitedList[$randomk]) {
$mixed_list[] = $UnitedList[$randomk];
unset($UnitedList[$randomk]);
++$i;
continue;
}

if (isset($mixed_list[$i - 1]) && $mixed_list[$i - 1] === $UnitedList[$randomk]) {
$newk = getKey($UnitedList, $UnitedList[$randomk]);
$mixed_list[] = $UnitedList[$newk];
unset($UnitedList[$newk]);
++$i;
continue;
}

++$i;
continue;
}

print_r($mixed_list);

?>

最好的结果:

Array
(
[0] => A
[1] => C
[2] => A
[3] => C
[4] => B
[5] => C
[6] => B
[7] => C
[8] => B
[9] => C
)

最坏结果:

Array
(
[0] => A
[1] => B
[2] => A
[3] => C
[4] => B
[5] => C
[6] => B
[7] => C
[8] => C
[9] => C
)

我需要以某种方式禁止最坏的结果类型结果,当连续有 3 个 C 时,如果至少有 3 个则更好。C 可以放在数组前面

最佳答案

所以,我对代码做了一些调整

<?php
function getKey(&$array, $not) {
$rk = array_rand($array);
if ($array[$rk] !== $not || count(array_unique($array)) === 1) {
return $rk;
}

return getKey($array, $not);
}

function getRandomizedList($listToRandomize) {
$mixed_list = [];
$i = 0;
shuffle($listToRandomize);

while (!empty($listToRandomize)) {
$randomk = array_rand($listToRandomize);

if ( $i === 0 ) {
$mixed_list[] = $listToRandomize[$randomk];
unset($listToRandomize[$randomk]);
++$i;
continue;
}

if (isset($mixed_list[$i - 1]) && $mixed_list[$i - 1] !== $listToRandomize[$randomk]) {
$mixed_list[] = $listToRandomize[$randomk];
unset($listToRandomize[$randomk]);
++$i;
continue;
}

if (isset($mixed_list[$i - 1]) && $mixed_list[$i - 1] === $listToRandomize[$randomk]) {
$newk = getKey($listToRandomize, $listToRandomize[$randomk]);
if ($mixed_list[$i - 1] === $listToRandomize[$newk] && $mixed_list[0] !== $listToRandomize[$newk]) {
array_unshift($mixed_list, $listToRandomize[$newk]);
} else {
$mixed_list[] = $listToRandomize[$newk];
}
unset($listToRandomize[$newk]);
++$i;
continue;
}

++$i;
continue;
}
return $mixed_list;
}


$UnitedList1 = [
'C',
'C',
'C',
'C',
'C',
'A',
'A',
'B',
'B',
'B'
];

$UnitedList2 = [
'C',
'C',
'C',
'C',
'C',
'A',
'A',
'A',
'A',
'A',
'B',
'B',
'B'
];

for ($i=0; $i < 5; $i++) {
echo "UnitedList1 i = $i";
print_r(getRandomizedList($UnitedList1));
echo "--\n\r";
}
echo "------\n\r";


for ($i=0; $i < 5; $i++) {
echo "UnitedList2 i = $i";
print_r(getRandomizedList($UnitedList2));
echo "--\n\r";
}
echo "------\n\r";
?>

和结果:

UnitedList1 i = 0Array
(
[0] => C
[1] => B
[2] => C
[3] => A
[4] => B
[5] => C
[6] => A
[7] => C
[8] => B
[9] => C
)
--

UnitedList1 i = 1Array
(
[0] => C
[1] => A
[2] => B
[3] => C
[4] => A
[5] => C
[6] => B
[7] => C
[8] => B
[9] => C
)
--

UnitedList1 i = 2Array
(
[0] => C
[1] => B
[2] => A
[3] => C
[4] => B
[5] => C
[6] => A
[7] => B
[8] => C
[9] => C
)
--

UnitedList1 i = 3Array
(
[0] => C
[1] => A
[2] => B
[3] => C
[4] => A
[5] => B
[6] => C
[7] => B
[8] => C
[9] => C
)
--

UnitedList1 i = 4Array
(
[0] => C
[1] => B
[2] => C
[3] => B
[4] => A
[5] => C
[6] => B
[7] => C
[8] => A
[9] => C
)
--

------

UnitedList2 i = 0Array
(
[0] => C
[1] => A
[2] => C
[3] => A
[4] => C
[5] => A
[6] => B
[7] => C
[8] => B
[9] => C
[10] => A
[11] => B
[12] => A
)
--

UnitedList2 i = 1Array
(
[0] => C
[1] => A
[2] => C
[3] => A
[4] => C
[5] => A
[6] => B
[7] => C
[8] => A
[9] => C
[10] => B
[11] => A
[12] => B
)
--

UnitedList2 i = 2Array
(
[0] => A
[1] => B
[2] => C
[3] => A
[4] => C
[5] => A
[6] => C
[7] => B
[8] => A
[9] => C
[10] => B
[11] => C
[12] => A
)
--

UnitedList2 i = 3Array
(
[0] => C
[1] => A
[2] => C
[3] => B
[4] => A
[5] => C
[6] => B
[7] => A
[8] => B
[9] => A
[10] => C
[11] => A
[12] => C
)
--

UnitedList2 i = 4Array
(
[0] => A
[1] => C
[2] => A
[3] => B
[4] => C
[5] => B
[6] => A
[7] => C
[8] => A
[9] => B
[10] => C
[11] => A
[12] => C
)
--

------

关于php array shuffle/randomize array 所以没有两个相等的值不接近,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36350645/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com