溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何使用ASP.NET實現(xiàn)微信搶紅包

發(fā)布時間:2021-08-27 09:28:40 來源:億速云 閱讀:152 作者:小新 欄目:開發(fā)技術

這篇文章主要介紹如何使用ASP.NET實現(xiàn)微信搶紅包,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!

正文

100塊發(fā)30個紅包

  如何使用ASP.NET實現(xiàn)微信搶紅包如何使用ASP.NET實現(xiàn)微信搶紅包如何使用ASP.NET實現(xiàn)微信搶紅包如何使用ASP.NET實現(xiàn)微信搶紅包

50塊發(fā)13個紅包

  如何使用ASP.NET實現(xiàn)微信搶紅包如何使用ASP.NET實現(xiàn)微信搶紅包如何使用ASP.NET實現(xiàn)微信搶紅包如何使用ASP.NET實現(xiàn)微信搶紅包如何使用ASP.NET實現(xiàn)微信搶紅包

1塊發(fā)10個紅包

  如何使用ASP.NET實現(xiàn)微信搶紅包如何使用ASP.NET實現(xiàn)微信搶紅包如何使用ASP.NET實現(xiàn)微信搶紅包如何使用ASP.NET實現(xiàn)微信搶紅包如何使用ASP.NET實現(xiàn)微信搶紅包

發(fā)紅包需要滿足以下幾個條件

1.總金額不變
2.每個紅包都必須有錢
3.盡量的均勻點,不然搶紅包沒什么意思了 

實現(xiàn)思路
1.首先要確定最小單位,這里是精確到分,我這里以int類型進行計算,得出的結果也全是int類型
2.數(shù)據(jù)均勻,這里以  1<n<(剩余金額/剩余紅包數(shù))*2,這里防止一個紅包搶走大量的錢,這里需要寫個遞歸,去檢查數(shù)據(jù)值是否過大,50元發(fā)13個紅包的第3圖,就是因為沒有檢查數(shù)據(jù),導致錢不平均,這個可以根據(jù)自己的玩法去設置.
3.余數(shù)處理,當數(shù)據(jù)平均給20個紅包,肯定跟總金額有所偏差,這時候我們就要多退少補,如果大于總金額,讓紅包金額多的去減少(總金額/總人數(shù)),如果還有剩余,就讓第二多的去減少,直到補完這個空缺為止,反之亦然.
4.打亂順序,細心的園友可能發(fā)現(xiàn),紅包是有順序規(guī)律的,我們必須簡單的寫個function去打亂它.   

demo 

/// <summary>
 /// 搶紅包
 /// </summary>
 /// <param name="money"></param>
 /// <param name="num"></param>
 /// <returns></returns>
 public List<int> qhb(int money, int num)
 {
  int min = 1;
  int pjs = money / num;
  List<int> list = new List<int>();
  Random rnd = new Random();
  for (int i = 0; i < num; i++)
  {
  int max = (money / (num - i)) * 2;
  int s = rnd.Next(min, max);
  s = checkmoney(s, min, max);
  list.Add(s);
  money -= s;
  }
  //前面數(shù)據(jù)都是合理的,結尾必須多退少補
  list = checklist(money, pjs, list);
  return list;
 }
/// <summary>
 /// 余數(shù)處理
 /// </summary>
 /// <param name="money"></param>
 /// <param name="list"></param>
 /// <returns></returns>
 public List<int> checklist(int money, int pjs, List<int> list)
 {
  if (money != 0)
  {
  if (money > 0)
  {

   List<int> list_order = maopao(list);
   //給最小
   if (money / pjs == 0)
   {   
   list_order[0] += money;
   }
   else
   {
   for (int i = 0; i < money / pjs + 1; i++)
   {
    if (i == money / pjs)
    {
    list_order[i] += (money - (money / pjs) * pjs);
    }
    else
    {
    list_order[i] += pjs;
    }

   }
   }
   return list_order;
  }
  else
  {

   List<int> list_order = maopao(list,"desc");
   //給最大
   if (money / pjs == 0)
   {

   list_order[0] += money;
   }
   else
   {
   for (int i = 0; i < -(money / pjs) + 1; i++)
   {
    if (i == -(money / pjs))
    {
    list_order[i] += (money - (money / pjs) * pjs);
    }
    else
    {
    list_order[i] -= pjs;
    }

   }
   }
   return list_order;
  }
  }
  return list;
 }
 /// <summary>
  /// 冒泡排序
  /// </summary>
  /// <param name="list"></param>
  /// <param name="order"></param>
  /// <returns></returns>
  public List<int> maopao(List<int> list,string order = "asc")
  {
  if (order != "asc")
  {
   for (int i = 0; i < list.Count; i++)
   {
   for (int j = 0; j < list.Count - i - 1; j++)
   {
    if (list[j + 1] > list[j])
   {
    int temp = list[j];
    list[j] = list[j + 1];
    list[j + 1] = temp;
 
    }
   }
   }
  }
  else 
  {
   for (int i = 0; i < list.Count; i++)
   {
   for (int j = 0; j < list.Count-i-1;j++)
   {
    if (list[j+1] < list[j])
    {
    int temp = list[j];
    list[j] = list[j+1];
    list[j+1] = temp;

   }
   }
  }
  }
  return list;
 }
/// <summary>
 /// 打亂順序
  /// </summary>
  /// <param name="list"></param>
  /// <returns></returns>
 public List<int> suiji(List<int> list) 
  {
  Random rnd = new Random();
  for (int i = 0; i < list.Count; i++)
  {
   int temp = list[i];
   int j = rnd.Next(0, list.Count-1);
   list[i] = list[j];
   list[j] = temp;
  }
  return list;
 }

以上是“如何使用ASP.NET實現(xiàn)微信搶紅包”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業(yè)資訊頻道!

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內容。

AI