找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 1949|回复: 0
打印 上一主题 下一主题

php实现的微信红包算法分析(非官方)

[复制链接]

2536

主题

2536

帖子

7532

积分

论坛元老

Rank: 8Rank: 8

积分
7532
跳转到指定楼层
楼主
发表于 2018-2-14 05:42:41 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

            本文实例讲述了php实现的微信红包算法。分享给大家供大家参考。具体如下:
最近一直在微信群里体验红包功能,红包类型有两种:
1. 普通红包
2. 拼手气红包
普通红包就不用多解析了,大锅饭原理,平分。
拼手气红包讲的是手气(运气),有人可以抢到很多,有人抢的少得可怜,当然也不是先抢就一定多,说到底了就是随机。

想了想,自己写写看,能不能实现类似的功能(不敢说是算法)。
// $bonus_total 红包总金额
// $bonus_count 红包个数
// $bonus_type 红包类型 1=拼手气红包 0=普通红包
function randBonus($bonus_total=0, $bonus_count=3, $bonus_type=1){
  $bonus_items  = array(); // 将要瓜分的结果
  $bonus_balance = $bonus_total; // 每次分完之后的余额
  $bonus_avg   = number_format($bonus_total/$bonus_count, 2); // 平均每个红包多少钱
  $i       = 0;
  while($i
好吧,我们现在来体验一下
// 发3个拼手气红包,总金额是100元
$bonus_items  = randBonus(100, 3, 1);
// 查看生成的红包
var_dump($bonus_items);
// 校验总金额是不是正确,看看微信有没有坑我们的钱
var_dump(array_sum($bonus_items));
另一个使用数组实现的版本,原理差不多:
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
希望本文所述对大家的php程序设计有所帮助。
            
            
您可能感兴趣的文章:
  • php实现rc4加密算法代码
  • 一致性哈希算法以及其PHP实现详细解析
  • php加密算法之实现可逆加密算法和解密分享
  • 适用于抽奖程序、随机广告的PHP概率算法实例
  • 又一个PHP实现的冒泡排序算法分享
  • PHP 快速排序算法详解
  • PHP树的深度编历生成迷宫及A*自动寻路算法实例分析
  • php实现猴子选大王问题算法实例
  • PHP面试常用算法(推荐)
  • PHP经典算法集锦【经典收藏】
  • PHP实现基于回溯法求解迷宫问题的方法详解
  • php实现的生成迷宫与迷宫寻址算法完整实例
            
  • 分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
    收藏收藏
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    用户反馈
    客户端