java写的伪微信红包功能示例代码

 更新时间:2019年08月08日 14:14:58   作者:田小江  
这篇文章主要介绍了java写的伪微信红包功能示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

性能优化点:

1.使用int不使用double。(单位用分不用元)也省去了还要用math.round四舍五入,把double类型数据只留小数点后前两位。

2.random() 方法用于返回一个随机数,随机数范围为 0.0 =< Math.random < 1.0。所以,当每人只能分到1分钱时,不用生成随机数(随机数只能生成0分,不大于最小值,会死循环)。

import java.util.HashMap;
import java.util.Map;

public class WXTRedPackage {
  public static void main(String[] args) {
    WXTRedPackage wx = new WXTRedPackage();
    // 红包钱数(以分为单位),个数
    wx.WXMoney(1000, 50);
  }

  public void WXMoney(int sum, int num) {
    // 创建一个hashmap,把分配出来的人和钱顺序打乱
    Map<Integer, Integer> moneyMap = new HashMap();
    System.out.println("共计" + sum / 100 + "元红包,分成" + num + "份。开始:");
    int min = 0;
    int balance = sum;
    int money = 0;
    for (int i = 0; i < num; i++) {
      if ((double) sum / num == 1) {
        moneyMap.put(i, 1);
      } else {
        // 最大可分配数目为剩下的人每人至少1分钱
        int max = balance - (num - i - 1) * 1;
        // 获取一个0-最大可分配数的随机数
        money = (int) (Math.random() * max);
        // 最后一个人全分配最后的余额
        if (i == num - 1) {
          moneyMap.put(i, balance);
          break;
        } else {
          // 分配的金额要超过0份,小于最大可分配数,不符合要求则把人数减一重新循环一次
          if (money > min && money < max) {
            balance -= money;
            moneyMap.put(i, money);
          } else {
            i = i - 1;
          }
        }
      }
    }
    for (Integer key : moneyMap.keySet()) {
      System.out.println("第" + (key + 1) + "人获取红包"
          + (double) moneyMap.get(key) / 100 + "元!");
    }
  }
}

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

相关文章

  • 浅析对Spring aware接口理解

    浅析对Spring aware接口理解

    通过aware接口可以获取Spring容器相关信息,但这样会与Spring容器耦合,这篇文章主要介绍了Spring aware接口理解,需要的朋友可以参考下
    2022-08-08
  • SpringBoot集成pf4j实现插件开发功能的代码示例

    SpringBoot集成pf4j实现插件开发功能的代码示例

    pf4j是一个插件框架,用于实现插件的动态加载,支持的插件格式(zip、jar),本文给大家介绍了SpringBoot集成pf4j实现插件开发功能的示例,文中通过代码示例给大家讲解的非常详细,需要的朋友可以参考下
    2024-07-07
  • springboot配置https访问的方法

    springboot配置https访问的方法

    这篇文章主要介绍了springboot配置https访问的方法,需要的朋友可以参考下
    2018-11-11
  • Java中synchronized锁升级的过程

    Java中synchronized锁升级的过程

    本文主要介绍了Java中synchronized锁升级的过程,synchronized相对于早期的synchronized做出了优化,从以前的加锁就是重量级锁优化成了有一个锁升级的过,下文详细内容需要的小伙伴可以参考一下
    2022-05-05
  • spring boot配置读写分离的完整实现步骤

    spring boot配置读写分离的完整实现步骤

    数据库配置主从之后,如何在代码层面实现读写分离?所以下面这篇文章主要给大家介绍了关于spring boot配置读写分离的完整步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2018-09-09
  • IntelliJ IDEA安装scala插件并创建scala工程的步骤详细教程

    IntelliJ IDEA安装scala插件并创建scala工程的步骤详细教程

    这篇文章主要介绍了IntelliJ IDEA安装scala插件并创建scala工程的步骤,本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-07-07
  • 单机redis分布式锁实现原理解析

    单机redis分布式锁实现原理解析

    这篇文章主要介绍了单机redis分布式锁实现原理解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-04-04
  • Spring中的@PropertySource注解源码详细解析

    Spring中的@PropertySource注解源码详细解析

    这篇文章主要介绍了Spring中的@PropertySource注解源码详细解析,@PropertySource注解,标注在配置类@Configuration上面,下面主要分析一下@PropertySource注解的处理过程,也就是怎么把配置信息从.properies文件放到environment中的,需要的朋友可以参考下
    2024-01-01
  • Java多态的使用注意事项

    Java多态的使用注意事项

    本文讲解了什么是JAVA多态和Java多态是如何实现的,在使用Java多态时需要注意什么,具体大家看下面的内容
    2013-11-11
  • kafka 重新分配partition和调整replica的数量实现

    kafka 重新分配partition和调整replica的数量实现

    当需要提升Kafka集群的性能和负载均衡时,可通过kafka-reassign-partitions.sh命令手动重新分配Partition,增加节点后,可以将Topic的Partition的Leader节点均匀分布,以提高写入和消费速度,感兴趣的可以了解一下
    2022-03-03

最新评论