商品价格加价区间的实现(策略模式)

2023-10-27 22:40

本文主要是介绍商品价格加价区间的实现(策略模式),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言:

好久之前,某个网友提的需求,对商品进行加价,根据原商品的价格不同,加价的方式不同。

具体如下:

250元以下 按比率10%以内加价
251~500 加价 25元以下
501~5000  按比率 5%以内加价
5000以上 加价250元以下
比如某种商品价格是:6000或者10000按照5000元以上的标准调。

分析:

首先,加价是一个范围,因此我们先定义一个结构,PriceRange:

1 public struct PriceRange
2     {
3         public decimal MaxPrice { get; set; }
4         public decimal MinPrice { get; set; }
5     }

对于加价相关的逻辑,有两种,一种为固定加价,一种为按比率加价,因此利用策略模式处理如下(英文类名请无视,硬伤):

 1  public interface IPriceStrategy
 2     {
 3         PriceRange GetPriceRange(decimal purchasePrice);
 4     }
 5 
 6     /// <summary>
 7     /// 固定加价策略
 8     /// </summary>
 9     public class FixedPriceStrategy : IPriceStrategy
10     {
11         private decimal _fixedPrice;
12 
13         /// <summary>
14         /// 
15         /// </summary>
16         /// <param name="fixedPrice">加价金额</param>
17         public FixedPriceStrategy(decimal fixedPrice)
18         {
19             this._fixedPrice = fixedPrice;
20         }
21 
22         public PriceRange GetPriceRange(decimal purchasePrice)
23         {
24             return new PriceRange()
25             {
26                 MinPrice = purchasePrice,
27                 MaxPrice = purchasePrice + _fixedPrice,
28             };
29         }
30     }
31 
32     /// <summary>
33     /// 百分比加价策略
34     /// </summary>
35     public class PercentagePriceStrategy : IPriceStrategy
36     {
37         private decimal _percent;
38 
39         /// <summary>
40         /// 
41         /// </summary>
42         /// <param name="percent">加价率</param>
43         public PercentagePriceStrategy(decimal percent)
44         {
45             this._percent = percent;
46         }
47 
48         public PriceRange GetPriceRange(decimal purchasePrice)
49         {
50             return new PriceRange()
51             {
52                 MinPrice = purchasePrice,
53                 MaxPrice = purchasePrice * (1 + _percent),
54             };
55         }
56     }

最后需要一个工具类,封装相关加价逻辑,并暴漏一个方法出来:

PS:这里设计:每种加价策略的低价作为key,放到字典中。 获取加价区间时,取小于或等于 传入价格的所有Key中最大的一个(如果没有,则取最大的Key),即为最终的加价策略!

这样设计的好处:可以避免大量的if 和else if 。。。

 1 public class PriceUtility
 2     {
 3         /// <summary>
 4         /// 相关加价策略
 5         /// </summary>
 6         private static Dictionary<decimal, IPriceStrategy> Dic = new Dictionary<decimal, IPriceStrategy>();
 7 
 8         static PriceUtility()
 9         {
10             //初始化加价规则(todo:这里是写死的,如果需求多变,也可以从外部存储获取并初始化)
11             Dic.Add(0, new PercentagePriceStrategy(0.1m));
12             Dic.Add(250, new FixedPriceStrategy(25));
13             Dic.Add(500, new PercentagePriceStrategy(0.05m));
14             Dic.Add(5000, new FixedPriceStrategy(250));
15         }
16 
17         /// <summary>
18         /// 获取加价区间
19         /// </summary>
20         /// <param name="purchasePrice"></param>
21         /// <returns></returns>
22         public static PriceRange GetRange(decimal purchasePrice)
23         {
24             var key = GetCurrentKey(purchasePrice);
25 
26             return Dic[key].GetPriceRange(purchasePrice);
27         }
28 
29         /// <summary>
30         /// 获取符合条件的Key
31         /// </summary>
32         /// <param name="purchasePrice"></param>
33         /// <returns></returns>
34         private static decimal GetCurrentKey(decimal purchasePrice)
35         {
36             //找到小于等于该价格的所有Key
37             var keys = Dic.Keys.Where(r => r.CompareTo(purchasePrice) <= 0).ToArray();
38             //如果没有,则取最大的
39             if (keys.Length == 0) return Dic.Keys.Max();
40             //有则在找到的Key中取最大的
41             return keys.Max();
42         }
43     }

结果:

用控制台应用程序测试一下:

 1 static void Main(string[] args)
 2         {
 3             ConsolePriceRange(100);
 4             ConsolePriceRange(240);
 5             ConsolePriceRange(250);
 6             ConsolePriceRange(490);
 7             ConsolePriceRange(500);
 8             ConsolePriceRange(4900);
 9             ConsolePriceRange(5000);
10             ConsolePriceRange(10000);
11 
12             Console.ReadKey();
13         }
14 
15         static void ConsolePriceRange(decimal price)
16         {
17             PriceRange range = PriceUtility.GetRange(price);
18 
19             Console.WriteLine("产品价格{0}的加价区间为:{1}~{2}", price, range.MinPrice, range.MaxPrice);
20         }

转载于:https://www.cnblogs.com/hetring/p/4992474.html

这篇关于商品价格加价区间的实现(策略模式)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

hdu1043(八数码问题,广搜 + hash(实现状态压缩) )

利用康拓展开将一个排列映射成一个自然数,然后就变成了普通的广搜题。 #include<iostream>#include<algorithm>#include<string>#include<stack>#include<queue>#include<map>#include<stdio.h>#include<stdlib.h>#include<ctype.h>#inclu

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

【Prometheus】PromQL向量匹配实现不同标签的向量数据进行运算

✨✨ 欢迎大家来到景天科技苑✨✨ 🎈🎈 养成好习惯,先赞后看哦~🎈🎈 🏆 作者简介:景天科技苑 🏆《头衔》:大厂架构师,华为云开发者社区专家博主,阿里云开发者社区专家博主,CSDN全栈领域优质创作者,掘金优秀博主,51CTO博客专家等。 🏆《博客》:Python全栈,前后端开发,小程序开发,人工智能,js逆向,App逆向,网络系统安全,数据分析,Django,fastapi

让树莓派智能语音助手实现定时提醒功能

最初的时候是想直接在rasa 的chatbot上实现,因为rasa本身是带有remindschedule模块的。不过经过一番折腾后,忽然发现,chatbot上实现的定时,语音助手不一定会有响应。因为,我目前语音助手的代码设置了长时间无应答会结束对话,这样一来,chatbot定时提醒的触发就不会被语音助手获悉。那怎么让语音助手也具有定时提醒功能呢? 我最后选择的方法是用threading.Time

Android实现任意版本设置默认的锁屏壁纸和桌面壁纸(两张壁纸可不一致)

客户有些需求需要设置默认壁纸和锁屏壁纸  在默认情况下 这两个壁纸是相同的  如果需要默认的锁屏壁纸和桌面壁纸不一样 需要额外修改 Android13实现 替换默认桌面壁纸: 将图片文件替换frameworks/base/core/res/res/drawable-nodpi/default_wallpaper.*  (注意不能是bmp格式) 替换默认锁屏壁纸: 将图片资源放入vendo

在JS中的设计模式的单例模式、策略模式、代理模式、原型模式浅讲

1. 单例模式(Singleton Pattern) 确保一个类只有一个实例,并提供一个全局访问点。 示例代码: class Singleton {constructor() {if (Singleton.instance) {return Singleton.instance;}Singleton.instance = this;this.data = [];}addData(value)

C#实战|大乐透选号器[6]:实现实时显示已选择的红蓝球数量

哈喽,你好啊,我是雷工。 关于大乐透选号器在前面已经记录了5篇笔记,这是第6篇; 接下来实现实时显示当前选中红球数量,蓝球数量; 以下为练习笔记。 01 效果演示 当选择和取消选择红球或蓝球时,在对应的位置显示实时已选择的红球、蓝球的数量; 02 标签名称 分别设置Label标签名称为:lblRedCount、lblBlueCount

hdu 1754 I Hate It(线段树,单点更新,区间最值)

题意是求一个线段中的最大数。 线段树的模板题,试用了一下交大的模板。效率有点略低。 代码: #include <stdio.h>#include <string.h>#define TREE_SIZE (1 << (20))//const int TREE_SIZE = 200000 + 10;int max(int a, int b){return a > b ? a :

Kubernetes PodSecurityPolicy:PSP能实现的5种主要安全策略

Kubernetes PodSecurityPolicy:PSP能实现的5种主要安全策略 1. 特权模式限制2. 宿主机资源隔离3. 用户和组管理4. 权限提升控制5. SELinux配置 💖The Begin💖点点关注,收藏不迷路💖 Kubernetes的PodSecurityPolicy(PSP)是一个关键的安全特性,它在Pod创建之前实施安全策略,确保P

工厂ERP管理系统实现源码(JAVA)

工厂进销存管理系统是一个集采购管理、仓库管理、生产管理和销售管理于一体的综合解决方案。该系统旨在帮助企业优化流程、提高效率、降低成本,并实时掌握各环节的运营状况。 在采购管理方面,系统能够处理采购订单、供应商管理和采购入库等流程,确保采购过程的透明和高效。仓库管理方面,实现库存的精准管理,包括入库、出库、盘点等操作,确保库存数据的准确性和实时性。 生产管理模块则涵盖了生产计划制定、物料需求计划、