生成一个列表,分成几个区间,例如列表长度100,1-20是靴子的区间,21-45是披风的区间等,然后随机从100取出一个数,看落在哪个区间。算法时间复杂度:预处理O(MN),随机数生成O(1),空间复杂度O(MN),其中N代表物品种类,M则由最低概率决定。

php代码实现如下:

1,'prize'=>'一等奖','v'=>1),     array('id'=>2,'prize'=>'二等奖','v'=>5),     array('id'=>3,'prize'=>'三等奖','v'=>10),     array('id'=>4,'prize'=>'四等奖','v'=>12),     array('id'=>5,'prize'=>'五等奖','v'=>22),     array('id'=>6,'prize'=>'六等奖','v'=>50)); shuffle($prize_arr);$arr = array();foreach ($prize_arr as $key => $val) {    $arr[] = $val['v'];}$zjx = get_rand($arr);if($zjx < 0){    echo '未中奖';    }else{    echo $prize_arr[$zjx]['prize'];}function get_rand($proArr) {     $result = -1;     $proSum = array_sum($proArr);    foreach ($proArr as $key => $proCur)     {         $randNum = mt_rand(1, $proSum);        if ($randNum <= $proCur)         {             $result = $key;             break;         }         else         {            $proSum -= $proCur;         }     }     return $result; }