最近做项目遇到这样一个问题,是关于一个考试的项目:
要求A/B/C/D的答案不能始终在一样的位置,所以就要进行重新组装随机出来了。
黏上代码
<?php
header("Content-type: text/html; charset=utf-8");
$array=[
'choice'=>['直角三角形','锐角三角形','钝角三角形','天角三角形']
];
function random_arr($array){
$count = count($array['choice']); //获取数组的长度
$arr=array();
while(count($arr)<$count)
{
$num = rand(0,$count-1);
$arr[]=$array['choice'][$num]; //重新进行组装
$arr=array_unique($arr); //去除重复的
}
$arr = array_merge ($arr); //下标重新进行排序
$result['choice']=$arr; //转换成二位的数组,重新返回回去
return $result;
}
var_dump(random_arr($array));
/*输入结果,这些都是随机排列的
$result = [
'choice'=>[
'0'=>'天角三角形',
'1'=>'钝角三角形',
'2'=>'直角三角形',
'3'=>'锐角三角形',
]
]
*/
exit();
?>
#注意:发现如果数据量比较大的情况下,这个我写的函数其实并不好用,耗时那是相当的长。后来我去网上找了下,发现php就有自带一个这样子的函数,shuffle()。具体用法自行百度。