Home >Backend Development >PHP Tutorial >PHP probability algorithm examples suitable for lottery programs and random advertisements_PHP tutorial
Then we will definitely design an algorithm in the program, that is, let the user win the prize according to a certain probability. Let’s first look at two probability algorithm functions.
Algorithm 1
if (!isset($arr[$key])) {
$max = array_sum($ps);
foreach ($ps as $k=>$v) {
$ v = $v / $max * 10000;
for ($i=0; $i<$v; $i++) $arr[$key][] = $k;
}
}
Return $arr[$key][mt_rand(0,count($arr[$key])-1)];
}
//Total probability accuracy of probability array
$proSum = array_sum($proArr);
//Probability array loop
foreach ($proArr as $key => $proCur) {
$randNum = mt_rand(1, $proSum);
if ($randNum <= $ proCur) {
$result = $key; 🎜> unset ($proArr);
Return $result;
}
The above code is a classic probability algorithm. $proArr is a preset array. Assume that the array is: array(100,200,300,400), starting from 1 , within the probability range of 1000, screen whether the first number is within its occurrence probability range. If not, the probability is reduced, that is, the value of k minus the probability space of the number just now, in this case Subtract 100, which means that the second number is filtered within the range of 1,900. In this way, until the end, there will always be a number that meets the requirements. It's like touching something in a box. If the first one isn't there, the second one isn't there, and the third one isn't there, then the last one must be. This algorithm is simple and very efficient. The key is that this algorithm has been applied in our previous projects, especially in projects with large amounts of data. The efficiency is very good.
Next we configure the awards through PHP.
$rid = get_rand($arr); //Get the award id based on probability
$res['yes'] = $prize_arr[$rid-1]['prize']; //Winning prizes
//Remove the winning prizes from the array, leaving the unwon prizes, if Database verification, you can omit here
unset($prize_arr[$rid-1]);
shuffle($prize_arr); //Disrupt the order of the array
for($i=0;$i< count($prize_arr);$i++){
$pr[] = $prize_arr[$i]['prize'];
}
$res['no'] = $pr;
echo json_encode($res);
Why can’t I draw the grand prize?
In many similar lottery activities, participants often cannot win the grand prize. The author will give you an example from a program perspective. If I am the organizer of the lottery event, I have set up 6 awards. Each award Different winning probabilities. If the first prize is a luxury car, but I set the winning probability to 0, what does this mean? This means that no matter how many draws, the lottery participants will never get this luxury car. And when the organizer flips the remaining squares every time, the participants will find that the first prize may be under a number next to the square that was just drawn, and they blame their bad luck. Is it really bad luck? In fact, when the participant flipped that square, the program had already determined the prize, but when he flipped the other squares to see the prize, he saw just a *, which confused the audience and participants. I think after reading this article, you may know that the flip lottery in TV shows is tricky, and you may never choose a double color ball by machine again.