首页 > 学院 > 逻辑算法 > 正文

算法也疯狂 实现假装商品抢购繁忙的效果(php版

2020-03-22 19:17:58
字体:
来源:转载
供稿:网友
  • 很多做电商开发的小伙伴会遇到这个需求。

    譬如我们要做一个 商品限时秒杀的功能。 其实如果你的网站很有流量,那么很多用户在几秒内同时点你的商品,确实会出现“抢购人数太多,请排队”。

    但是呢,大部分网站然而并没有这么牛叉。为了让用户感受到商品很抢手,动不动就提示”系统繁忙“的效果,我们需要做一个程序来”假装很繁忙“。 (除了淘宝,大家不要以为其他网站真的很繁忙哦,只不过人家是故意让你觉得不抢就买不到,求懂)

    本文来设定一个规则,大家可以根据我的思路扩展即可。
    1、商品购买链接,每个人都可以点。
    2、我们要让用户有70%的可能性出现“排队中,商品繁忙”

    本文用 php代码实现。其他语言一样,改改。

    首先我们用小学学到的知识想一下:
    1、 如果有10个球,其中3个红球,7个篮球。放在袋子里。随便胡乱的混合一下,让你用手伸进去摸,那么摸到篮球的几率是多少?显然,是70%

    之前我把这个需求给了一个小伙伴看。他给出的答案如下:
    $arr=array(“red”,”red”,”red”,”blue”,”blue”,”blue”,”blue”,”blue”,”blue”,”blue”);
    然后 echo $arr[rand(0,9)];
    然后告诉我,他两句话就搞定了。

    这个做法其实已经蛮聪明了。但是这位小伙伴忽略了很重要的一点

    2、如果第二个人来摸呢? 这里有个注意点,如果第二个人来摸,那么必定要把这10个球补满(依然是3个红球,7个篮球)
    然后最重要的,还要继续“胡乱的、随便的”混合一下。这样,第二个人来摸到篮球的几率才会依然是70%.

    上面的程序明显忽略了:继续“胡乱的、随便的”混合一下。 如果每个人都按这个 前三个红后七个蓝 来摸球。那么php的rand函数不能保证篮球是70%。

    说到这,很多大神要拿出各种高级算法,譬如啥贝叶斯、矩阵之类的字眼出来。如果这么一个电商功能要用这么复杂的运算,我相信你的老板不会同意你花这么多时间来完成这个功能吧。

    接下来,我放出一种简单,但也不失精准性的算法。我们的目标是:使用php的简单函数,尽可能的让摸到篮球的几率接近于70%。

    第一步: $arr=array(“red”,”red”,”red”,”blue”,”blue”,”blue”,”blue”,”blue”,”blue”,”blue”); 这个东西要有,这就是初始化的三个红球,7个篮球


    第二步:随意的、胡乱的混合。

    上面一个数组有10个元素,我们可以采取随机两个球交换,交换多少次可以自己定

    先写个交换函数 (如果这个函数看不懂,就要恶补基础知识啦)
    function swap($i,$j,$arr)
    {
    $tmp=$arr[$i];
    $arr[$i]=$arr[$j];
    $arr[$j]=$tmp;
    return $arr;
    }
    这个函数实现,我输入两个随便什么序号,实现对这个数组中符合该序号的求交换一下。

    第三步:优化交换算法。
    因为上面的交换函数,输入的随机参数导致,红球和红球交换,或者篮球和篮球交换。那么然而并没有实现“真正的”混合

    所以我们要写个补充函数,确保每次交换,都必须是红球和篮球进行随意交换

    function getRange($arr,$v)
    {
    $ret=array();
    for($i=0;$i<count($arr);$i++)
    {
    if($arr[$i]==$v)
    {
    $ret[]=$i;
    }
    }
    return $ret[rand(0,count($ret)-1)];
    }
    这个函数的作用是:在10个球中找到 红球或篮球,然后分别取出他们目前所在的序号,然后利用rand函数随机取一个篮球或者红球的序号。

    诺看一下这里:

    $i=getRange($arr,”red”); //这样可以取出随机一个红球的序号
    $j=getRange($arr,”blue”); //这样可以取出随机一个篮球的序号

    第四步:比较重要。开始随意的、胡乱的混合

    for($num=0;$num<10;$num++)
    {

    $i=getRange($arr,”red”);
    $j=getRange($arr,”blue”);

    $arr=swap($i,$j,$arr);

    // echo implode(“,”, $arr).”|”.$i.”|”.$j.”<br/>”; //这个语句可以看一下输出,混合过后的排列,是否每次都不一样
    }

    这里的注意点是,$num<10 。代表我混合10次。 等于用你的大手到袋子里胡乱搅10次。 理论上搅的越多,随机性越强。这里其实10次足以。

    第四步执行完成后出来的$arr 就是搅拌好的 红球和篮球的混合体。

    第五步:再次调用 rand函数

    echo $arr[rand(0,9)];

    如果出来的是内容是blue ,则直接exit(“老子很忙,别烦”)
    如果是red,那么让程序继续执行购买程序吧。

    这个大家自己编写吧。

    我的视频教学

    1、[速学]centos+docker基础实战

    2、《从此不求人:自主研发一套PHP前端开发框架

    ————————————————–

    【你如果不爱读书、不爱看新闻、不爱学习,没关系。我来做你的”陪读郎”】

    奴隶我的方式:请关注微信订阅号:程序员在囧途。

    每天讲故事、讲商业模式、讲技术给你听。

    我的个人站点:www.hishenyi.com

    PHP编程

    郑重声明:本文版权归原作者所有,转载文章仅为传播更多信息之目的,如作者信息标记有误,请第一时间联系我们修改或删除,多谢。

  • 发表评论 共有条评论
    用户名: 密码:
    验证码: 匿名发表