>  기사  >  백엔드 개발  >  복권 프로그램 당첨 확률 알고리즘을 구현한 PHP의 예

복권 프로그램 당첨 확률 알고리즘을 구현한 PHP의 예

黄舟
黄舟원래의
2017-11-15 11:16:384237검색

우리는 일상 업무에서 복권 활동에 자주 참여하므로 오늘은 스크래치 카드, 큰 바퀴 및 기타 복권 알고리즘에 사용할 수 있는 PHP 당첨 확률 알고리즘을 공유하겠습니다. 사용법은 매우 간단합니다. 코드에 자세한 설명 지침이 있으므로 필요한 친구는 참고할 수 있습니다.

먼저 백엔드 PHP 프로세스를 완료합니다. PHP의 주요 작업은 보상과 해당 당첨 확률을 구성하는 것입니다. 프런트 엔드 페이지에서 특정 상자를 클릭하면 백엔드 PHP에 Ajax 요청이 전송됩니다. 그러면 백엔드 PHP는 확률 알고리즘을 통과하여 당첨 결과를 제공하고 동시에 당첨되지 않은 상금 정보는 JSON 데이터 형식으로 프런트 엔드 페이지로 전송됩니다.

먼저 확률 계산 함수를 살펴보겠습니다

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; 
}

위 코드는 고전적인 확률 알고리즘입니다. $proArr은 미리 설정된 배열입니다. 배열은 1,1000 화면의 확률 범위에서 시작합니다. 첫 번째 숫자가 발생 확률 범위 내에 있는지 여부. 그렇지 않은 경우 k 값에서 방금 숫자의 확률 공간을 뺍니다. 즉, 두 번째 숫자는 범위 내에서 필터링됩니다. 범위는 1,900입니다. 이런 식으로 끝까지 요구 사항을 충족하는 숫자는 항상 존재합니다. 이는 상자 안의 무언가를 만지는 것과 같습니다. 첫 번째 것도 없고, 두 번째도 없고, 세 번째도 없으면 마지막 것도 있어야 합니다. 이 알고리즘은 간단하고 매우 효율적입니다. 중요한 점은 이 알고리즘이 이전 프로젝트, 특히 대용량 데이터가 있는 프로젝트에 적용되었다는 것입니다.

다음으로 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), 
);

2차원 배열은 이 복권의 모든 경품 정보를 기록합니다. 여기서 id는 당첨 수준을 나타내고, Prize는 경품을 나타내며, v는 당첨 확률을 나타냅니다. v는 정수여야 합니다. 해당 상금의 v를 0으로 설정할 수 있습니다. 이는 상을 받을 확률이 0이라는 것을 의미합니다. 배열(기본)에 있는 v의 합은 더 커집니다. 확률이 반영될 수 있습니다. 이 예에서 v의 합이 100이면 태블릿의 당첨 확률은 1%입니다. v의 합이 10,000이면 당첨 확률은 1/10000입니다.

프런트 엔드 페이지가 요청될 때마다 PHP는 상 설정 배열을 반복하고 확률 계산 함수 get_rand를 통해 추첨된 상 ID를 얻습니다. 당첨된 상품은 $res['yes'] 배열에 저장하고, 나머지 당첨되지 않은 정보는 $res['no']에 저장한 후 마지막으로 json 번호 데이터를 프런트엔드 페이지에 출력합니다.

 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);

첨부된 내용은 네티즌의 구현 방법이기도 합니다

/**
  * 抽奖
  * @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;
  ?>

요약:

이 글을 공부하는 과정을 통해 여러분은 PHP의 복권 프로그램 당첨 확률 알고리즘에 대해 어느 정도 이해하게 되리라 믿습니다. 도움이 되길 바랍니다. 작업에 도움이 됩니다!

관련 추천:

php 복권 프로그램 및 무작위 광고 구현 알고리즘

PHP 복권 프로그램 핵심 코드(행운의 시청자 3명 추첨)

PHP 복권 프로그램 확률 알고리즘

위 내용은 복권 프로그램 당첨 확률 알고리즘을 구현한 PHP의 예의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.