群主发红包带你深入了解继承和super、this关键字

2023-10-21 14:30

本文主要是介绍群主发红包带你深入了解继承和super、this关键字,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

需求

群主发随机红包或者普通红包。某群有多名成员,群主给成员发普通红包。
随机红包规则:

  1. 群主的一笔金额,从群主余额中扣除,随机分成n等份,让成员领取。
  2. 成员领取红包后,保存到成员余额中。

普通红包的规则:

  1. 群主的一笔金额,从群主余额中扣除,平均分成n等份,让成员领取。
  2. 成员领取红包后,保存到成员余额中。

案例分析

案例分析,可以得出如下继承关系:
在这里插入图片描述

案例代码实现

定义用户类

/*** 用户类* @author zjq*/
public class User {/*** 姓名*/private String name;/*** 余额,也就是当前用户拥有的钱数*/private Integer money; public User() {}public User(String name, Integer money) {this.name = name;this.money = money;}// 展示一下当前用户有多少钱public void show() {System.out.println("我是" + name + ",我有多少钱:" + this.fenToYuan(String.valueOf(money))+"元");}public String getName() {return name;}public void setName(String name) {this.name = name;}public Integer getMoney() {return money;}public void setMoney(Integer money) {this.money = money;}/*** 分转元* @param amount* @return*/public   String fenToYuan(String amount){NumberFormat format = NumberFormat.getInstance();try{Number number = format.parse(amount);double temp = number.doubleValue() / 100.0;format.setGroupingUsed(false);format.setMaximumFractionDigits(2);amount = format.format(temp);} catch (ParseException e){e.printStackTrace();}return amount;}}

定义群主类

package com.zjq.javabase.base09.demo14;import org.apache.commons.lang3.RandomUtils;
import java.util.ArrayList;/*** 群主的类* @author zjq*/
public class Manager extends User {/*** 收到单个红包最大值*/private static final int MAX_AMOUNT = 20000;public Manager() {}public Manager(String name, int money) {// 通过super 调用父类构造方法super(name, money);}/*** 发红包* @param totalMoney 红包总金额(单位分)* @param count 发包个数* @param type 发包类型(0、随机红包,1、定额红包)* @return 红包集合* @throws Exception*/public ArrayList<Integer> send(Integer totalMoney, int count,int type) throws Exception {// 首先需要一个集合,用来存储若干个红包的金额ArrayList<Integer> redList = new ArrayList<>(count);// 首先看一下群主自己有多少钱Integer leftMoney = super.getMoney(); // 群主当前余额if (totalMoney > leftMoney) {System.out.println("余额不足");return redList; // 返回空集合}// 扣钱,其实就是重新设置余额super.setMoney(leftMoney - totalMoney);if (count == 1) {redList.add(totalMoney);return redList;}switch (type) {case 0:// 默认分配1分至每一位for (int i = 0; i < count; i++) {redList.add(1);}int surplus_currency = totalMoney - redList.size(),// 剩余金额数surplus_number = redList.size();// 剩余需追加的数量for (int i = 0; i < redList.size(); i++) {// 没值可以追加了if (new Integer(0).equals(surplus_currency)) {break;}// (总数-(总包-i)*最小值) / (总包 - i) 随机安全值算法int safe_total = (int)Math.floor((totalMoney - (count - i)) / (count - i));if (new Integer(0).equals(safe_total)) {// 随机值不能为0safe_total = 1;}// 该次随机值int randomint = surplus_currency >= safe_total - 1 ? safe_total : surplus_currency + 1;// 下次可能最大能剩余值int nextMax_currency = (MAX_AMOUNT - 1) * (surplus_number - 1);// 最小的随机数     剩余金额-剩余最大随机的总数(不含这一次)int minRandom = surplus_currency -  nextMax_currency;if (minRandom < 0) {minRandom = 0;}// 规避一些特殊情况,每个接近2000或1时会发生boolean must = (surplus_currency - count * MAX_AMOUNT <= 2 && surplus_currency - count * MAX_AMOUNT >= 0)/*|| surplus_currency < packet_number * 2*/;// 控制安全随机值           随机安全值不能大于最大限制,并且不能小于最小限 制if (safe_total < minRandom || safe_total > MAX_AMOUNT || must) {safe_total = MAX_AMOUNT;// 该次随机值randomint = surplus_currency >= safe_total - 1 ? safe_total : surplus_currency + 1;// 下次可能最大能剩余值nextMax_currency = (randomint - 1) * (surplus_number - 1);// 最小的随机数     剩余金额-剩余最大随机的总数(不含这一次)minRandom = surplus_currency -  nextMax_currency;if (minRandom < 0) {minRandom = 0;}}// 下一次最大的随机值int nextMaxRandomInt = nextMax_currency - (surplus_currency - (randomint - 1));Integer maxRandom = nextMaxRandomInt <= 0 ? nextMaxRandomInt + randomint: null;// 能随机          剩余的金额  - 最大随机数 >  最大随机数  * 剩余数量boolean canRandom = surplus_currency - (randomint - 1) > nextMax_currency ||nextMaxRandomInt > (randomint - 1)|| !new Integer(0).equals(minRandom);int addNumber; // 追加的金额if (canRandom && !new Integer(randomint).equals(minRandom+1) && !(new Integer(randomint).equals(minRandom) && new Integer(safe_total).equals(minRandom)) ) {addNumber = myRandom(minRandom, maxRandom == null ? randomint : maxRandom- 1);}else {addNumber = randomint - 1;}redList.set(i,redList.get(i) + addNumber);surplus_currency -= addNumber;surplus_number--;}break;case 1:// 定额红包校验redList = new ArrayList<>(count);for (int i = 0; i <count; i++) {//定额红包要是不能整除会有问题,正常实现应该是输入单个红包金额和总数直接就能计算redList.add(totalMoney/count);}break;default:throw new Exception("类型错误!");}System.out.println("我是" + this.getName() + "我发了"+fenToYuan(String.valueOf(totalMoney))+"元红包"+",我现在有多少钱:" + fenToYuan(String.valueOf(this.getMoney()))+"元");return redList;}/*** 生成随机金额* @param min* @param randomint* @return*/public static int myRandom(int min,int randomint) {if (min == 0) {return  RandomUtils.nextInt(0,randomint);}else {int nextInt = RandomUtils.nextInt(min,randomint - min);return nextInt + min;}}
}

定义成员类

/*** 普通成员* @author zjq*/
public class Member extends User {public Member() {}public Member(String name, Integer money) {super(name, money);}public void receive(ArrayList<Integer> list) {// 从多个红包当中随便抽取一个,给我自己。// 随机获取一个集合当中的索引编号int index = new Random().nextInt(list.size());// 根据索引,从集合当中删除,并且得到被删除的红包,给我自己Integer delta = list.remove(index);// 当前成员自己本来有多少钱:Integer money = super.getMoney();// 加法,并且重新设置回去super.setMoney(money + delta);System.out.println("我是" + this.getName() + ",我抢到了"+fenToYuan(String.valueOf(delta))+"元红包"+",我现在有多少钱:" + fenToYuan(String.valueOf(this.getMoney()))+"元");}
}

定义测试类

public class MainRedPacket {public static void main(String[] args) throws Exception {Manager manager = new Manager("群主", 10000);Member member1 = new Member("张三", 1000);Member member2 = new Member("李四", 1000);Member member3 = new Member("王五", 1000);Member member4 = new Member("赵六", 1000);Member member5 = new Member("孙七", 1000);Member member6 = new Member("小詹", 1000);Member member7 = new Member("小明", 1000);Member member8 = new Member("小红", 1000);manager.show(); // 100member1.show(); // 10member2.show(); // 10member3.show(); // 10member4.show(); // 10member5.show(); // 10member6.show(); // 10member7.show(); // 10member8.show(); // 10System.out.println("============================");// 群主总共发20块钱,分成8个红包ArrayList<Integer> redList = manager.send(2000, 8,0);// 八个普通成员收红包member1.receive(redList);member2.receive(redList);member3.receive(redList);member4.receive(redList);member5.receive(redList);member6.receive(redList);member7.receive(redList);member8.receive(redList);}}

结果输出如下:
在这里插入图片描述

这篇关于群主发红包带你深入了解继承和super、this关键字的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/254998

相关文章

关于数据埋点,你需要了解这些基本知识

产品汪每天都在和数据打交道,你知道数据来自哪里吗? 移动app端内的用户行为数据大多来自埋点,了解一些埋点知识,能和数据分析师、技术侃大山,参与到前期的数据采集,更重要是让最终的埋点数据能为我所用,否则可怜巴巴等上几个月是常有的事。   埋点类型 根据埋点方式,可以区分为: 手动埋点半自动埋点全自动埋点 秉承“任何事物都有两面性”的道理:自动程度高的,能解决通用统计,便于统一化管理,但个性化定

【前端学习】AntV G6-08 深入图形与图形分组、自定义节点、节点动画(下)

【课程链接】 AntV G6:深入图形与图形分组、自定义节点、节点动画(下)_哔哩哔哩_bilibili 本章十吾老师讲解了一个复杂的自定义节点中,应该怎样去计算和绘制图形,如何给一个图形制作不间断的动画,以及在鼠标事件之后产生动画。(有点难,需要好好理解) <!DOCTYPE html><html><head><meta charset="UTF-8"><title>06

深入探索协同过滤:从原理到推荐模块案例

文章目录 前言一、协同过滤1. 基于用户的协同过滤(UserCF)2. 基于物品的协同过滤(ItemCF)3. 相似度计算方法 二、相似度计算方法1. 欧氏距离2. 皮尔逊相关系数3. 杰卡德相似系数4. 余弦相似度 三、推荐模块案例1.基于文章的协同过滤推荐功能2.基于用户的协同过滤推荐功能 前言     在信息过载的时代,推荐系统成为连接用户与内容的桥梁。本文聚焦于

【C++高阶】C++类型转换全攻略:深入理解并高效应用

📝个人主页🌹:Eternity._ ⏩收录专栏⏪:C++ “ 登神长阶 ” 🤡往期回顾🤡:C++ 智能指针 🌹🌹期待您的关注 🌹🌹 ❀C++的类型转换 📒1. C语言中的类型转换📚2. C++强制类型转换⛰️static_cast🌞reinterpret_cast⭐const_cast🍁dynamic_cast 📜3. C++强制类型转换的原因📝

深入手撕链表

链表 分类概念单链表增尾插头插插入 删尾删头删删除 查完整实现带头不带头 双向链表初始化增尾插头插插入 删查完整代码 数组 分类 #mermaid-svg-qKD178fTiiaYeKjl {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-

深入理解RxJava:响应式编程的现代方式

在当今的软件开发世界中,异步编程和事件驱动的架构变得越来越重要。RxJava,作为响应式编程(Reactive Programming)的一个流行库,为Java和Android开发者提供了一种强大的方式来处理异步任务和事件流。本文将深入探讨RxJava的核心概念、优势以及如何在实际项目中应用它。 文章目录 💯 什么是RxJava?💯 响应式编程的优势💯 RxJava的核心概念

深入理解数据库的 4NF:多值依赖与消除数据异常

在数据库设计中, "范式" 是一个常常被提到的重要概念。许多初学者在学习数据库设计时,经常听到第一范式(1NF)、第二范式(2NF)、第三范式(3NF)以及 BCNF(Boyce-Codd范式)。这些范式都旨在通过消除数据冗余和异常来优化数据库结构。然而,当我们谈到 4NF(第四范式)时,事情变得更加复杂。本文将带你深入了解 多值依赖 和 4NF,帮助你在数据库设计中消除更高级别的异常。 什么是

JavaSE——封装、继承和多态

1. 封装 1.1 概念      面向对象程序三大特性:封装、继承、多态 。而类和对象阶段,主要研究的就是封装特性。何为封装呢?简单来说就是套壳屏蔽细节 。     比如:对于电脑这样一个复杂的设备,提供给用户的就只是:开关机、通过键盘输入,显示器, USB 插孔等,让用户来和计算机进行交互,完成日常事务。但实际上:电脑真正工作的却是CPU 、显卡、内存等一些硬件元件。

速了解MySQL 数据库不同存储引擎

快速了解MySQL 数据库不同存储引擎 MySQL 提供了多种存储引擎,每种存储引擎都有其特定的特性和适用场景。了解这些存储引擎的特性,有助于在设计数据库时做出合理的选择。以下是 MySQL 中几种常用存储引擎的详细介绍。 1. InnoDB 特点: 事务支持:InnoDB 是一个支持 ACID(原子性、一致性、隔离性、持久性)事务的存储引擎。行级锁:使用行级锁来提高并发性,减少锁竞争

Oracle Start With关键字

Oracle Start With关键字 前言 旨在记录一些Oracle使用中遇到的各种各样的问题. 同时希望能帮到和我遇到同样问题的人. Start With (树查询) 问题描述: 在数据库中, 有一种比较常见得 设计模式, 层级结构 设计模式, 具体到 Oracle table中, 字段特点如下: ID, DSC, PID; 三个字段, 分别表示 当前标识的 ID(主键), DSC 当