C#实现拼手气红包算法

本文实例为大家分享了C#实现拼手气红包算法的具体代码,供大家参考,具体内容如下

一、方案1:即开即中,考虑机会均等,减少金额差较大的几率

可以每次点击时候,随机产生

static double[] GetRandomMoney(double money, int n)
 {
  double[] array = new double[n];
  RedPackage red = new RedPackage() { money = money, count = n };
  for (int i = 0; i < n; i++)
  {
   array[i] = GetRandomMoney(red);
  }
  return array;
 }
 /// <summary>
 /// 即开即中,考虑机会均等,减少金额差较大的几率
 /// 随机产生,额度在0.01和剩余平均值*2之间
 /// </summary>
 /// <returns></returns>
 static double GetRandomMoney(RedPackage redPackage)
 {
  //如果最后一个,返回全部
  if (redPackage.count == 1)
  {
   redPackage.count--;
   return Math.Round(redPackage.money * 100) / 100.00;
  }
  //随机生成
  Random ran = new Random();
  double min = 0.01;
  double max = redPackage.money / redPackage.count * 2;
  double money = ran.NextDouble() * max;

  money = money <= min ? 0.01 : money;
  money = Convert.ToInt32(money * 100) / 100.00;
  redPackage.count--;
  redPackage.money -= money;
  return money;
 }
 public class RedPackage
 {
  /// <summary>
  /// 剩余红包数量
  /// </summary>
  public int count;
  /// <summary>
  /// 剩余金额
  /// </summary>
  public double money;
 }

生成5组随机结果如下:

二、方案2: 一次性拆分红包,不考虑机会平等性

/// <summary>
/// 一次性拆分红包,不考虑机会平等性
/// 最小单位1 分
/// </summary>
 static double[] DiviedOne(double money, int n)
 {

  double min = 0.01;
  if (money < min)
   throw new Exception("拆分金额不能小于0.01 ");
  int fen = (int)money * 100;
  //创建n 个红包数组
  int[] array = new int[n];
  //每个红包先填充1分
  Array.Fill(array, 1);
  fen -= n;

  //第二步,随机分配
  Random ran = new Random();
  int i = 0;
  while (fen > 1)
  {
   int f = ran.Next(fen);
   array[i % n] += f;
   fen -= f;
   i++;
  }
  //最后一分钱,补到第一个数组
  if (fen > 0)
  {
   array[0] += fen;
  }

  return array.Select(q => q / 100.0).ToArray();
 }

生成5组随机结果如下:

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • C#公众号开发之给用户发红包

    红包功能简单介绍: 1.商户调用接口时,通过指定发送对象以及发送金额的方式发放红包,这样的方式,允许商户灵活的应用于各种各样丰富的活动场景 2.领取到红包后,用户的资金直接进入微信零钱,避免繁复的领奖流程,带给用户微信支付原生的流畅体验 现金红包官网文档地址 调用现金红包接口需要使用到证书,请前往商户平台下载证书 官网有关详细证书的介绍,点击查看 因为发送现金红包是从商户平台余额扣款,所以商户平台的账户余额必须有充足的余额 下面是调用红包接口详细代码: 1.签名的MD5加密类: /// <sum

  • C#实现微信红包功能

    本文实例为大家分享了C#仿微信红包功能的具体代码,供大家参考,具体内容如下 Program.cs代码: class Program { static void Main(string[] args) { //初始化要发起的红包基础数据 double total = 100; int num = 50; double min = 0.01; string temp; bool flag = false; Console.WriteLine(string.Format("是否需要自定义红包金额和数量

  • C#实现拼手气红包算法

    本文实例为大家分享了C#实现拼手气红包算法的具体代码,供大家参考,具体内容如下 一.方案1:即开即中,考虑机会均等,减少金额差较大的几率 可以每次点击时候,随机产生 static double[] GetRandomMoney(double money, int n) { double[] array = new double[n]; RedPackage red = new RedPackage() { money = money, count = n }; for (int i = 0; i

  • java实现微信红包 拼手气红包

    本文实例为大家分享了java实现微信红包的具体代码,供大家参考,具体内容如下 要求 基于BigDecimal类实现微信红包算法的功能,比如设置红包总金额,然后设置需要生成的红包个数,为每个红包随机指定金额,最低不能低于0.01元,要求: 1.每个红包金额随机指定 2.每个红包金额不能低于0.01元 3.要求每个红包的金额之和恰好等于总金额 4.如果平均每个红包的金额不足0.01元时抛出一个RedPacketException,提示每个红包金额不能少于0.01元 实现方法 该题主要考察java常用

  • PHP实现的随机红包算法示例

    本文实例讲述了PHP实现的随机红包算法.分享给大家供大家参考,具体如下: 一.整体设计 算法有很多种, 可以自行选择, 主要的"架构" 是这样的, 用redis decr()命令去限流, 用mysql去记录各种需要的数据 二.红包算法 简便起见, 红包金额用整数表示, 假设每个红包里边有x个糖豆, 每个人最少一个豆 第一种: 每个红包的最大金额是: (剩余金额/剩余红包数)*2, 需要开始的时候预先分配给每个人一个豆 function randBean($total_bean, $to

  • JavaScript实现微信红包算法及问题解决方法

    专栏停更了很久,向大家说声抱歉.今天的主题是使用JavaScript模拟实现微信抢红包的算法.这个题目看起来很简单,不就是一个随机函数吗?我们一起实现看看. 我们假设有一个100元的红包,要发给10个人.为了保证公平,算法需要保证以下的原则: 每个人最少能抢到0.01元 每个人的机会平等 所有人的金额之和等于100元 1.简单的随机函数实现 很多朋友的一般思路是: 第一步:从0-100中随机一个数,得到第一个红包金额. 第二步:从0-剩余金额中随机一个数,得到第二个红包金额. 第三步:... 最

  • java 模仿拼多多红包递减算法的实现

    该说不唠,直接上代码.可直接复制使用 package com.yuezhi.util; import java.math.BigDecimal; /** * @ProjectName yuezhi * @ClassName HongBaoUtils * @Description 网页分享红包算法 * @Author Wednesday * @Date 2020/2/4 14:45 * @Version 1.0 **/ public class HongBaoUtils { /** * 随机200

  • java模拟实现微信红包算法

    本文实例为大家分享了java实现微信红包算法的具体代码,供大家参考,具体内容如下 实现过程 1.代码如下(示例): import java.math.BigDecimal; import java.util.ArrayList; public class GenRedPacket { static ArrayList<BigDecimal> list = new ArrayList<BigDecimal>();; public static BigDecimal bianLiJia

  • 大家在抢红包,程序员在研究红包算法

    除夕全天微信用户红包总发送量达到10.1亿次,摇一摇互动量达到110亿次,红包峰值发送量为8.1亿次/分钟. 抛开微信红包的市场价值不谈,红包本身的算法也引发了热议,由于官方没有给出明确的说法,各家也是众说纷纭,小编下面也为大家带来几种分析. 首先看看数据分析帝 大多数人都做出自己的猜测,这也是在不知道内部随机算法的时候的唯一选择,但是大多数人没有给出自己亲自的调查结果.这里给出一份100样本的调查抽样样本数据,并提出自己的猜测. 1. 钱包钱数满足截尾正态随机数分布.大致为在截尾正态分布中取随

  • java 微信随机红包算法代码实例

    前几天的一个晚上突然想到微信红包应该有一个随机算法,就自己试着写了下,也不知道对不对,看了看网上的说法,好像到现在为止官方也没有给出一个确切的算法,只好在这里献丑了,先贴出代码: public static double [] getMoney(double money, int num){ Random r = new Random(); DecimalFormat format = new DecimalFormat(".##"); double middle = Double.p

  • 微信红包随机生成算法php版

    想了想,自己写写php版的微信红包随机生成算法,能不能实现类似的功能(其实也不敢说是算法). // $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

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

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

随机推荐