JAVA计算双十一多产品实付款优惠券的省钱方案
为了计算双十一期间多产品使用优惠券后的实付款省钱方案,我们需要一个更复杂的逻辑来处理优惠券的应用和叠加规则。以下是一个简化的Java示例,用于展示如何计算多种优惠券应用于多个产品后的实付款金额,并找出最省钱的方案。
首先,我们定义一些类和方法:
Product
类表示产品,包含名称和价格。Coupon
类表示优惠券,包含类型(如满减、折扣等)、金额、使用条件(如满多少元可用)以及适用的产品集合(如果有的话)。Order
类表示订单,包含要购买的产品列表和已应用的优惠券列表。ShoppingCart
类表示购物车,用于管理订单和计算实付款金额。
然后,我们实现一个方法来生成所有可能的优惠券组合,并计算每种组合下的实付款金额。最后,我们找出实付款金额最小的组合,即为最省钱的方案。
import java.util.*; class Product { String name; double price; public Product(String name, double price) { this.name = name; this.price = price; }
} class Coupon { String type; // 优惠券类型,如"满减"、"折扣"等 double amount; // 优惠券金额或折扣比例 double condition; // 使用条件,如满多少元可用 Set<String> applicableProducts; // 适用的产品集合(可选) public Coupon(String type, double amount, double condition, Set<String> applicableProducts) { this.type = type; this.amount = amount; this.condition = condition; this.applicableProducts = applicableProducts; } // 判断优惠券是否可用于给定的产品集合 public boolean isApplicable(Set<Product> products) { if (applicableProducts == null || applicableProducts.isEmpty()) { return true; // 没有指定适用产品,则可用于所有产品 } for (Product product : products) { if (applicableProducts.contains(product.name)) { return true; // 至少有一个适用产品 } } return false; // 没有适用产品 } // 计算优惠券优惠金额 public double calculateDiscount(double totalPrice) { if (type.equals("满减")) { return Math.min(amount, totalPrice - condition); // 满减不能超过总价减去条件金额 } else if (type.equals("折扣")) { return totalPrice * (1 - amount / 100); // 折扣是以百分比形式给出 } return 0; }
} class Order { List<Product> products; List<Coupon> appliedCoupons; public Order(List<Product> products) { this.products = products; this.appliedCoupons = new ArrayList<>(); } // 计算订单总价(未应用优惠券) public double calculateTotalPrice() { return products.stream().mapToDouble(product -> product.price).sum(); } // 计算订单实付款金额(已应用优惠券) public double calculateFinalPrice() { double totalPrice = calculateTotalPrice(); double discount = appliedCoupons.stream().mapToDouble(coupon -> coupon.calculateDiscount(totalPrice)).sum(); return totalPrice - discount; }
} class ShoppingCart { List<Product> products; List<Coupon> coupons; public ShoppingCart(List<Product> products, List<Coupon> coupons) { this.products = products; this.coupons = coupons; } // 生成所有可能的优惠券组合,并找出最省钱的方案 public Order findBestDiscountScheme() { int n = coupons.size(); Order bestOrder = null; double minFinalPrice = Double.MAX_VALUE; // 递归生成所有优惠券组合 generateCouponCombinations(0, new ArrayList<>(), products, (couponsToApply) -> { Order order = new Order(new ArrayList<>(products)); order.appliedCoupons.addAll(couponsToApply); double finalPrice = order.calculateFinalPrice(); if (finalPrice < minFinalPrice) { minFinalPrice = finalPrice; bestOrder = order; } }); return bestOrder; } // 递归生成优惠券组合的辅助方法 private void generateCouponCombinations(int index, List<Coupon> currentCombination, List<Product> products, Consumer<List<Coupon>> callback) { if (index == coupons.size()) { // 达到递归终点,调用回调方法处理当前组合 callback.accept(new ArrayList<>(currentCombination)); return; } // 不使用当前优惠券 generateCouponCombinations(index + 1, currentCombination, products, callback); // 使用当前优惠券(如果可用) Coupon coupon = coupons.get(index); Set<Product> productSet = products.stream().collect(Collectors.toSet()); if (coupon.isApplicable(productSet)) { List<Coupon> newCombination = new ArrayList<>(currentCombination); newCombination.add(coupon); generateCouponCombinations(index + 1, newCombination, products, callback); } }
} public class Main { public static void main(String[] args) { List<Product> products = Arrays.asList( new Product("产品1", 100), new Product("产品2", 200), new Product("产品3", 300) ); List<Coupon> coupons = Arrays.asList( new Coupon("满减", 50, 300, null), // 满300减50,适用于所有产品 new Coupon("折扣", 90, 100, new HashSet<>(Arrays.asList("产品1"))) // 满100打9折,仅适用于产品1 ); ShoppingCart cart = new ShoppingCart(products, coupons); Order bestOrder = cart.findBestDiscountScheme(); System.out.println("最省钱的方案:"); System.out.println("实付款金额:" + bestOrder.calculateFinalPrice()); System.out.println("已应用的优惠券:"); for (Coupon coupon : bestOrder.appliedCoupons) { System.out.println(coupon.type + " " + coupon.amount + " " + coupon.condition + " " + (coupon.applicableProducts != null ? coupon.applicableProducts : "所有产品")); } }
}
请注意,这个示例代码有几个假设和简化:
- 优惠券可以叠加使用,但实际应用中可能有更复杂的规则。
- 优惠券的适用产品是通过名称匹配的,实际应用中可能需要更复杂的逻辑来确定哪些产品适用。
- 没有处理优惠券使用次数的限制。
- 没有处理优惠券和促销活动之间的优先级关系。
相关文章:
JAVA计算双十一多产品实付款优惠券的省钱方案
为了计算双十一期间多产品使用优惠券后的实付款省钱方案,我们需要一个更复杂的逻辑来处理优惠券的应用和叠加规则。以下是一个简化的Java示例,用于展示如何计算多种优惠券应用于多个产品后的实付款金额,并找出最省钱的方案。 首先࿰…...

零售行业的数字化营销转型之路
一方面,市场竞争激烈,电商平台、新兴品牌和跨界对手带来巨大压力。另一方面,消费者需求变化迅速,更加追求个性化、多元化和便捷化的购物体验,同时传统零售企业还面临着高成本压力,如租金、人力和库存等。 然…...
js的for in 和 for of的详解
for...in 和 for...of 是 JavaScript 中的两种循环结构,它们用于不同的场景,适用于不同的数据类型。下面将详细介绍它们的用法、区别以及适用场景。 1. for...in 循环 for...in 用于遍历对象的可枚举属性(包括继承的属性)。 语…...
前端工具函数库
流行的前端工具函数库 lodashlodash-es:用lodash-es代替lodashes-toolkit:https://www.npmjs.com/package/es-toolkitradash:https://github.com/sodiray/radash 补充信息: antd-mobile 已不再依赖 lodash, 淘汰 lo…...

Java程序设计:Spring boot(4)——Freemarker Thymeleaf视图技术集成
1 Freemarker 视图集成 SpringBoot 内部⽀持 Freemarker 视图技术的集成,并提供了⾃动化配置类 FreeMarkerAuto Configuration,借助⾃动化配置可以很⽅便的集成 Freemarker基础到 SpringBoot 环境中。这⾥借助⼊⻔项⽬引⼊ Freemarker 环境配置。 Start…...
JavaScript 第19章:Web Storage
在JavaScript中,Web存储(Web Storage)提供了一种在用户浏览器中持久化数据的方式。这里我们会探讨localStorage、sessionStorage以及IndexedDB,并提供一些简单的示例代码来展示它们的用法。 localStorage localStorage允许你在用…...
[山河2024] week2
官方WP出得很快。对照官的写下私的。大概出入不大,毕竟第2周。后边的才难。 Crypto E&R RSA因子分解题,把q的2进制反转后与p异或。关于异或的题很多,这个还真是头一回见,不过爆破方法还是一样的。 r_q int(bin(q)[2:][::…...

无限可能LangChain——开启大模型世界
什么是大语言模型? 大语言模型是一种人工智能模型,通常使用深度学习技术(如神经网络)来理解和生成人类语言。这些模型拥有非常多的参数,可以达到数十亿甚至更多,使得它们能够处理高度复杂的语言模式。 我…...
URL路径以及Tomcat本身引入的jar包会导致的 SpringMVC项目 404问题、Tomcat调试日志的开启及总结
一、URL路径导致的 SpringMVC项目 404问题 SpringMVC项目的各项代码都没有问题,但是在页面请求时仍然显示404,编译的时候报了下面的问题: org.apache.jasper.servlet.TldScanner.scanJars 至少有一个JAR被扫描用于TLD但尚未包含TLD。 为此记录…...

如何引起Java中的System.in.read()函数的异常
演示的为:关闭标准输入流System.in后再调用System.in.read就会报出IOException import java.io.IOException; import java.io.InputStream;public class Test {public static void main(String[] args) {InputStream in System.in;try {in.close();System.in.read();}catch (…...
深入理解Flutter鸿蒙next版本 中的Widget继承:使用extends获取数据与父类约束
目录 写在前面 什么是Widget继承? 基本概念 StatelessWidget与StatefulWidget build方法 创建自定义Widget 1. 继承StatelessWidget 2. 继承StatefulWidget并访问父类的约束 3. 继承其他自定义Widget并获取数据 写在最后 写在前面 在Flutter中,…...
Loss:Focal Loss for Dense Object Detection
目录 3. 焦点损失(Focal Loss)3.1. 平衡交叉熵3.2. 焦点损失定义3.3. 类别不平衡与模型初始化3.4. 类别不平衡与两阶段检测器4. RetinaNet 检测器。4.1. 推理与训练。3. 焦点损失(Focal Loss) 焦点损失(Focal Loss)旨在解决单阶段目标检测场景中训练时前景和背景类别之间…...
Unity3D中Excel表格的数据处理模块详解
前言 在Unity3D项目中,处理Excel表格数据是一项常见且重要的任务。通过Excel表格,我们可以方便地管理游戏配置、角色属性等数据内容。本文将详细介绍如何在Unity3D中实现Excel表格的数据处理模块,包括技术详解和代码实现。 对惹,…...

【python】OpenCV—Fun Mirrors
文章目录 1、准备工作2、原理介绍3、代码实现4、效果展示5、参考 1、准备工作 pip install vacm2、原理介绍 在OpenCV中,VCAM 库是一个用于简化创建三维曲面、定义虚拟摄像机、设置参数以及进行投影任务的工具。它特别适用于实现如哈哈镜等图像变形效果。 一、VC…...
QT IEEE754 16进制浮点数据转成10进制
IEEE754标准转换QT代码 qtcreator使用的ieee754标准的4字节数组与浮点数之间的转换方法,ieee754的4位数组如果转换成二进制后,大体结构是: 位序号12-910-32意义 符号位, 正数为0,负数为1. 指数位, 指数是…...

无人机+视频推流直播EasyCVR视频汇聚/EasyDSS平台在森林防护巡检中的解决方案
随着科技的飞速发展,无人机技术在各个领域的应用日益广泛,特别是在森林防护与巡检方面,无人机以其独特的优势,为传统林业管理带来了革命性的变化。本文将探讨无人机在森林防护巡检中的解决方案,分析其工作原理、优势及…...

Rancher—多集群Kubernetes管理平台
目录 一、Rancher 简介1.1 Rancher 和 k8s 的区别 二、Rancher 安装及配置2.1 安装 rancher2.2 登录 Rancher 平台2.3 Rancher 管理已存在的 k8s 集群2.4 创建名称空间 namespace2.5 创建 Deployment 资源2.6 创建 service2.7 Rancher 部署监控系统 一、Rancher 简介 Rancher …...
使用多IP香港站群服务器对网站管理seo优化提升排名有益处
在网站管理和优化中,选择合适的服务器是至关重要的。针对某些特定需求,使用多IP香港站群服务器可以带来明显的益处。本文将探讨使用多IP香港站群服务器 对网站管理的明显益处,并介绍其中的关键要点和优势。 I. 理解多IP香港站群服务器 1. 多I…...

网管平台(基础篇):网管系统的重要性
网管系统的核心地位:数字世界的稳定舵手 在信息技术日新月异的今天,网络如同一条无形的纽带,将世界紧密相连。然而,这条纽带背后隐藏着无数复杂的节点与链路,如何确保它们高效、稳定地运行,成为了一个亟待解…...

Ubuntu20.04下安装多CUDA版本,以及后续切换卸载
本方案的前提是假设机子上已经有一个版本的cuda,现在需要支持新的torch2.1.2和torchvision0.16.2,于是来安装新的cuda 一、选择版本 如果我想安装支持torch2.1.2的cuda版本,到官网(https://pytorch.org/get-started/previous-ve…...

LBE-LEX系列工业语音播放器|预警播报器|喇叭蜂鸣器的上位机配置操作说明
LBE-LEX系列工业语音播放器|预警播报器|喇叭蜂鸣器专为工业环境精心打造,完美适配AGV和无人叉车。同时,集成以太网与语音合成技术,为各类高级系统(如MES、调度系统、库位管理、立库等)提供高效便捷的语音交互体验。 L…...
Java 语言特性(面试系列2)
一、SQL 基础 1. 复杂查询 (1)连接查询(JOIN) 内连接(INNER JOIN):返回两表匹配的记录。 SELECT e.name, d.dept_name FROM employees e INNER JOIN departments d ON e.dept_id d.dept_id; 左…...

盘古信息PCB行业解决方案:以全域场景重构,激活智造新未来
一、破局:PCB行业的时代之问 在数字经济蓬勃发展的浪潮中,PCB(印制电路板)作为 “电子产品之母”,其重要性愈发凸显。随着 5G、人工智能等新兴技术的加速渗透,PCB行业面临着前所未有的挑战与机遇。产品迭代…...
macOS多出来了:Google云端硬盘、YouTube、表格、幻灯片、Gmail、Google文档等应用
文章目录 问题现象问题原因解决办法 问题现象 macOS启动台(Launchpad)多出来了:Google云端硬盘、YouTube、表格、幻灯片、Gmail、Google文档等应用。 问题原因 很明显,都是Google家的办公全家桶。这些应用并不是通过独立安装的…...

对WWDC 2025 Keynote 内容的预测
借助我们以往对苹果公司发展路径的深入研究经验,以及大语言模型的分析能力,我们系统梳理了多年来苹果 WWDC 主题演讲的规律。在 WWDC 2025 即将揭幕之际,我们让 ChatGPT 对今年的 Keynote 内容进行了一个初步预测,聊作存档。等到明…...
在鸿蒙HarmonyOS 5中使用DevEco Studio实现录音机应用
1. 项目配置与权限设置 1.1 配置module.json5 {"module": {"requestPermissions": [{"name": "ohos.permission.MICROPHONE","reason": "录音需要麦克风权限"},{"name": "ohos.permission.WRITE…...
【C++从零实现Json-Rpc框架】第六弹 —— 服务端模块划分
一、项目背景回顾 前五弹完成了Json-Rpc协议解析、请求处理、客户端调用等基础模块搭建。 本弹重点聚焦于服务端的模块划分与架构设计,提升代码结构的可维护性与扩展性。 二、服务端模块设计目标 高内聚低耦合:各模块职责清晰,便于独立开发…...
全面解析各类VPN技术:GRE、IPsec、L2TP、SSL与MPLS VPN对比
目录 引言 VPN技术概述 GRE VPN 3.1 GRE封装结构 3.2 GRE的应用场景 GRE over IPsec 4.1 GRE over IPsec封装结构 4.2 为什么使用GRE over IPsec? IPsec VPN 5.1 IPsec传输模式(Transport Mode) 5.2 IPsec隧道模式(Tunne…...
稳定币的深度剖析与展望
一、引言 在当今数字化浪潮席卷全球的时代,加密货币作为一种新兴的金融现象,正以前所未有的速度改变着我们对传统货币和金融体系的认知。然而,加密货币市场的高度波动性却成为了其广泛应用和普及的一大障碍。在这样的背景下,稳定…...

关键领域软件测试的突围之路:如何破解安全与效率的平衡难题
在数字化浪潮席卷全球的今天,软件系统已成为国家关键领域的核心战斗力。不同于普通商业软件,这些承载着国家安全使命的软件系统面临着前所未有的质量挑战——如何在确保绝对安全的前提下,实现高效测试与快速迭代?这一命题正考验着…...