java模拟微信抢红包的实例代码

作者:袖梨 2022-06-29

java简单模拟微信抢红包功能,本例发100元红包,有10个人抢,为了尽可能的公平,每个人的红包金额都要随机(保证结果的不确定性,本例抢红包的次序与红包金额匹配也随机),就是不能出现部分红包偏大部分偏小的情况,在区间0~100上随机生成9个节点,加0和100共11个节点按从小到大排序,各节点之间的差值就是红包金额,保证了红包金额之和等于100。

 代码如下 复制代码

publicstaticvoidmain(String[] args)

{

  // 发100元红包,10人抢

  // TODO Auto-generated method stub

  // 发红包总金额100元

  doubleS =100;

  // 0-100之间9个节点,加首尾11个点赋值给数组a

  double[] a =newdouble[11];

  // 第一个数是0

  a[0] =0;

  // 最后一个数是100

  a[a.length -1] = S;

  // 生成9个数随机节点并保留两位小数

  for(intm =1; m < a.length -1; m++)

  {

    a[m] = Double.valueOf(String.format("%.2f", S * Math.random()));

  }

  // 冒泡排序对9个点进行排序

  for(inti =1; i < a.length -2; i++)

  {

    for(intj =1; j < a.length -1- i; j++)

    {

      if(a[j] > a[j +1])

      {

        doubletemp;

        temp = a[j];

        a[j] = a[j +1];

        a[j +1] = temp;

      }

    }

  }

  //红包金额赋值给数组aa

  double[] aa =newdouble[a.length -1];

  // 后一项减前一项的差值为红包金额

  for(intn =0; n < a.length -1; n++)

  {

    doublemon = a[n +1] - a[n];

    //用自己的算法实现四舍五入保留两位小数

    intn1 = (int) (mon *1000);

    intc = n1 %10;

    if(c >4)

      mon = (double) ((n1 +10) /10) /100;

    else

      mon = (double) (n1 /10) /100;

    aa[n] = mon;

  }

  //列表打乱数组aa中的顺序,实现抢红包的次序与红包金额匹配随机

  List list =newArrayList<>();

  for(inti =0; i < aa.length; i++)

  {

    list.add(aa[i]);

  }

  Collections.shuffle(list);

  for(doublei:list)

  System.out.println(i);

}


相关文章

精彩推荐