Heim  >  Artikel  >  Backend-Entwicklung  >  Beispiel für eine PHP-Implementierung des Gewinnwahrscheinlichkeitsalgorithmus eines Lotterieprogramms

Beispiel für eine PHP-Implementierung des Gewinnwahrscheinlichkeitsalgorithmus eines Lotterieprogramms

黄舟
黄舟Original
2017-11-15 11:16:384156Durchsuche

In unserer täglichen Arbeit nehmen wir oft an einigen Lotterieaktivitäten teil, daher stellen wir Ihnen heute den PHP-Gewinnwahrscheinlichkeitsalgorithmus vor, der für Rubbellose, Riesenräder und andere Lotteriealgorithmen verwendet werden kann. Die Verwendung ist sehr einfach. Der Code enthält detaillierte Kommentare-Anweisungen, die auf einen Blick verstanden werden können.

Lassen Sie uns zunächst den Backend-PHP-Prozess abschließen. Die Hauptaufgabe von PHP besteht darin, die Auszeichnungen und die entsprechende Gewinnwahrscheinlichkeit zu konfigurieren. Wenn die Front-End-Seite auf ein bestimmtes Feld klickt, wird eine Ajax-Anfrage gesendet Das Backend-PHP konfiguriert es dann entsprechend der Wahrscheinlichkeit, das Gewinnergebnis wird über den Wahrscheinlichkeitsalgorithmus angegeben und die nicht gewonnenen Preisinformationen werden auch im JSON-Datenformat an die Front-End-Seite gesendet.

Sehen wir uns zunächst die Wahrscheinlichkeitsberechnungsfunktion an

function get_rand($proArr) { 
  $result = ''; 
 
  //概率数组的总概率精度 
  $proSum = array_sum($proArr); 
 
  //概率数组循环 
  foreach ($proArr as $key => $proCur) { 
    $randNum = mt_rand(1, $proSum); 
    if ($randNum <= $proCur) { 
      $result = $key; 
      break; 
    } else { 
      $proSum -= $proCur; 
    } 
  } 
  unset ($proArr); 
 
  return $result; 
}

Der obige Code ist ein klassischer Wahrscheinlichkeitsalgorithmus. $proArr ist ein voreingestelltes Array. Der erste Schritt besteht darin, zu prüfen, ob die erste Zahl im Wahrscheinlichkeitsbereich von 1.1000 liegt. Wenn dies nicht der Fall ist, wird der Wahrscheinlichkeitsraum verwendet, d. h. der Wahrscheinlichkeitsraum der Zahl minus dem Wert von k Im Beispiel wird 100 subtrahiert, was bedeutet, dass die zweite Zahl im Bereich von 1.900 gefiltert wird. So bleibt bis zum Schluss immer eine Nummer übrig, die den Anforderungen entspricht. Es ist, als würde man etwas in einer Kiste berühren. Wenn das erste nicht da ist, das zweite nicht da ist und das dritte nicht da ist, dann muss das letzte da sein. Dieser Algorithmus ist einfach und sehr effizient. Der Schlüssel ist, dass dieser Algorithmus in unseren vorherigen Projekten angewendet wurde, insbesondere in Projekten mit großen Datenmengen.

Als nächstes konfigurieren wir die Auszeichnungen über PHP.

$prize_arr = array( 
  &#39;0&#39; => array(&#39;id&#39;=>1,&#39;prize&#39;=>&#39;平板电脑&#39;,&#39;v&#39;=>1), 
  &#39;1&#39; => array(&#39;id&#39;=>2,&#39;prize&#39;=>&#39;数码相机&#39;,&#39;v&#39;=>5), 
  &#39;2&#39; => array(&#39;id&#39;=>3,&#39;prize&#39;=>&#39;音箱设备&#39;,&#39;v&#39;=>10), 
  &#39;3&#39; => array(&#39;id&#39;=>4,&#39;prize&#39;=>&#39;4G优盘&#39;,&#39;v&#39;=>12), 
  &#39;4&#39; => array(&#39;id&#39;=>5,&#39;prize&#39;=>&#39;10Q币&#39;,&#39;v&#39;=>22), 
  &#39;5&#39; => array(&#39;id&#39;=>6,&#39;prize&#39;=>&#39;下次没准就能中哦&#39;,&#39;v&#39;=>50), 
);

Das zweidimensionale Array zeichnet alle Preisinformationen dieser Lotterie auf, wobei id die Gewinnstufe, award den Preis und v die Gewinnwahrscheinlichkeit darstellt. Beachten Sie, dass v eine Ganzzahl sein muss. Sie können das v des entsprechenden Preises auf 0 setzen, was bedeutet, dass die Wahrscheinlichkeit, den Preis zu gewinnen, 0 ist. Je größer die Basis, desto mehr genau kann die Wahrscheinlichkeit wiedergegeben werden. In diesem Beispiel beträgt die Summe von v 100, dann beträgt die Gewinnwahrscheinlichkeit für das Tablet 1 %. Wenn die Summe von v 10.000 beträgt, beträgt die Gewinnwahrscheinlichkeit eins zu zehntausend.

Jedes Mal, wenn die Front-End-Seite angefordert wird, durchläuft PHP das Award-Setting-Array und erhält die gezogene Award-ID über die Wahrscheinlichkeitsberechnungsfunktion get_rand. Speichern Sie die Gewinnerpreise im Array $res['yes'], speichern Sie die verbleibenden nicht gewinnenden Informationen in $res['no'] und geben Sie schließlich die JSON-Nummerndaten auf der Front-End-Seite aus.

 foreach ($prize_arr as $key => $val) { 
   $arr[$val[&#39;id&#39;]] = $val[&#39;v&#39;]; 
 } 
 
 $rid = get_rand($arr); //根据概率获取奖项id 
 
 $res[&#39;yes&#39;] = $prize_arr[$rid-1][&#39;prize&#39;]; //中奖项 
 unset($prize_arr[$rid-1]); //将中奖项从数组中剔除,剩下未中奖项 
 shuffle($prize_arr); //打乱数组顺序 
 for($i=0;$i<count($prize_arr);$i++){ 
   $pr[] = $prize_arr[$i][&#39;prize&#39;]; 
 } 
 $res[&#39;no&#39;] = $pr; 
 echo json_encode($res);

Im Anhang finden Sie eine Implementierungsmethode für Internetnutzer

/**
  * 抽奖
  * @param int $total
  */
  function getReward($total=1000)
  {
  $win1 = floor((0.12*$total)/100);
  $win2 = floor((3*$total)/100);
  $win3 = floor((12*$total)/100);
  $other = $total-$win1-$win2-$win3;
  $return = array();
  for ($i=0;$i<$win1;$i++)
  {
  $return[] = 1;
  }
  for ($j=0;$j<$win2;$j++)
  {
  $return[] = 2;
  }
  for ($m=0;$m<$win3;$m++)
  {
  $return[] = 3;
  }
  for ($n=0;$n<$other;$n++)
  {
  $return[] = &#39;谢谢惠顾&#39;;
  }
  shuffle($return);
  return $return[array_rand($return)];
  }
  $data = getReward();
  echo $data;
  ?>

Zusammenfassung:

Believe it Through Während des Studiums dieses Artikels hat jeder ein gewisses Verständnis für den Gewinnwahrscheinlichkeitsalgorithmus des Lotterieprogramms in PHP. Ich hoffe, dass er für Ihre Arbeit hilfreich sein wird!

Verwandte Empfehlungen:

PHP-Lotterieprogramm und Algorithmus zur Implementierung zufälliger Werbung

Kerncode des PHP-Lotterieprogramms (um drei glückliche Zuschauer zu ziehen)

PHP-Lotterieprogramm-Wahrscheinlichkeitsalgorithmus

Das obige ist der detaillierte Inhalt vonBeispiel für eine PHP-Implementierung des Gewinnwahrscheinlichkeitsalgorithmus eines Lotterieprogramms. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn