[算法也瘋狂]實現僞裝商品搶購繁忙的效果(php版)


   不少作電商開發的小夥伴會遇到這個需求。php

    譬如咱們要作一個 商品限時秒殺的功能。 其實若是你的網站頗有流量,那麼不少用戶在幾秒內同時點你的商品,確實會出現「搶購人數太多,請排隊」。程序員

    可是呢,大部分網站然而並無這麼牛叉。爲了讓用戶感覺到商品很搶手,動不動就提示」系統繁忙「的效果,咱們須要作一個程序來」僞裝很繁忙「。 (除了淘寶,你們不要覺得其餘網站真的很繁忙哦,只不過人家是故意讓你以爲不搶就買不到,求懂)算法

本文來設定一個規則,你們能夠根據個人思路擴展便可。
    一、商品購買連接,每一個人均可以點。
    二、咱們要讓用戶有70%的可能性出現「排隊中,商品繁忙」數組

    本文用 php代碼實現。其餘語言同樣,改改。微信

首先咱們用小學學到的知識想一下:
    一、 若是有10個球,其中3個紅球,7個籃球。放在袋子裏。隨便胡亂的混合一下,讓你用手伸進去摸,那麼摸到籃球的概率是多少?顯然,是70%
 ide

以前我把這個需求給了一個小夥伴看。他給出的答案以下:
     $arr=array(「red」,」red」,」red」,」blue」,」blue」,」blue」,」blue」,」blue」,」blue」,」blue」);
     而後 echo $arr[rand(0,9)];
     而後告訴我,他兩句話就搞定了。函數

這個作法其實已經蠻聰明瞭。可是這位小夥伴忽略了很重要的一點學習

 二、若是第二我的來摸呢? 這裏有個注意點,若是第二我的來摸,那麼一定要把這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,那麼讓程序繼續執行購買程序吧。

  這個你們本身編寫吧。


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

【你若是不愛讀書、不愛看新聞、不愛學習,不要緊。我來作你的」陪讀郎」】

奴隸個人方式:請關注微信訂閱號:程序員在囧途。

講故事、講商業模式、講技術給你聽。

我的站點:www.hishenyi.com

wKioL1V5xrqSysBDAAETs1-hPPM856.jpg

相關文章
相關標籤/搜索