当先锋百科网

首页 1 2 3 4 5 6 7

最近做项目遇到这样一个问题,是关于一个考试的项目:

要求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()。具体用法自行百度。