欧美一区二区三区老妇人-欧美做爰猛烈大尺度电-99久久夜色精品国产亚洲a-亚洲福利视频一区二区

php如何實現(xiàn)微信紅包算法-創(chuàng)新互聯(lián)

這篇文章將為大家詳細講解有關(guān)php如何實現(xiàn)微信紅包算法,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

成都創(chuàng)新互聯(lián)公司長期為1000+客戶提供的網(wǎng)站建設(shè)服務(wù),團隊從業(yè)經(jīng)驗10年,關(guān)注不同地域、不同群體,并針對不同對象提供差異化的產(chǎn)品和服務(wù);打造開放共贏平臺,與合作伙伴共同營造健康的互聯(lián)網(wǎng)生態(tài)環(huán)境。為五指山企業(yè)提供專業(yè)的做網(wǎng)站、網(wǎng)站制作五指山網(wǎng)站改版等技術(shù)服務(wù)。擁有10余年豐富建站經(jīng)驗和眾多成功案例,為您定制開發(fā)。

最近一直在微信群里體驗紅包功能,紅包類型有兩種:

1. 普通紅包

2. 拼手氣紅包

普通紅包就不用多解析了,大鍋飯原理,平分。

拼手氣紅包講的是手氣(運氣),有人可以搶到很多,有人搶的少得可憐,當(dāng)然也不是先搶就一定多,說到底了就是隨機。

php如何實現(xiàn)微信紅包算法

想了想,自己寫寫看,能不能實現(xiàn)類似的功能(不敢說是算法)。

// $bonus_total 紅包總金額
// $bonus_count 紅包個數(shù)
// $bonus_type 紅包類型 1=拼手氣紅包 0=普通紅包
function randBonus($bonus_total=0, $bonus_count=3, $bonus_type=1){
  $bonus_items  = array(); // 將要瓜分的結(jié)果
  $bonus_balance = $bonus_total; // 每次分完之后的余額
  $bonus_avg   = number_format($bonus_total/$bonus_count, 2); // 平均每個紅包多少錢
  $i       = 0;
  while($i<$bonus_count){
    if($i<$bonus_count-1){
      $rand      = $bonus_type?(rand(1, $bonus_balance*100-1)/100):$bonus_avg; // 根據(jù)紅包類型計算當(dāng)前紅包的金額
      $bonus_items[] = $rand;
      $bonus_balance -= $rand;
    }else{
      $bonus_items[] = $bonus_balance; // 最后一個紅包直接承包最后所有的金額,保證發(fā)出的總金額正確
    }
    $i++;
  }
  return $bonus_items;
}

好吧,我們現(xiàn)在來體驗一下

// 發(fā)3個拼手氣紅包,總金額是100元
$bonus_items  = randBonus(100, 3, 1);
// 查看生成的紅包
var_dump($bonus_items);
// 校驗總金額是不是正確,看看微信有沒有坑我們的錢
var_dump(array_sum($bonus_items));

另一個使用數(shù)組實現(xiàn)的版本,原理差不多:

function sendRandBonus($total=0, $count=3, $type=1){
  if($type==1){
    $input     = range(0.01, $total, 0.01);
    if($count>1){
      $rand_keys = (array) array_rand($input, $count-1);
      $last    = 0;
      foreach($rand_keys as $i=>$key){
        $current  = $input[$key]-$last;
        $items[]  = $current;
        $last    = $input[$key];
      }
    }
    $items[]    = $total-array_sum($items);
  }else{
    $avg      = number_format($total/$count, 2);
    $i       = 0;
    while($i<$count){
      $items[]  = $i<$count-1?$avg:($total-array_sum($items));
      $i++;
    }
  }
  return $items;
}

關(guān)于“php如何實現(xiàn)微信紅包算法”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,使各位可以學(xué)到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。

分享文章:php如何實現(xiàn)微信紅包算法-創(chuàng)新互聯(lián)
轉(zhuǎn)載來源:http://www.chinadenli.net/article38/dccjsp.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供微信小程序自適應(yīng)網(wǎng)站動態(tài)網(wǎng)站服務(wù)器托管云服務(wù)器小程序開發(fā)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

小程序開發(fā)