02策略模式

news/2024/9/21 3:32:25

1. 案例:营业员根据客户所购买商品的单价和数量,根据不同活动向客户收费**

- 正常原价收费
- 八折收费
- 满300返100

2. 策略模式结构

- 抽象策略类(Stategy):声明算法的方法,抽象层的设计使上下文类可以无差别的调用不同的具体策略的方法

enum CashType
{NORMAL = 0,REBATE,RETURN
};class CashSuper
{
public:virtual double AcceptCash(double dMoney) = 0;
};

- 具体策略类(Concrete Strategy):实现具体的算法

class CashNormal :public CashSuper
{
public:// 通过 CashSuper 继承double AcceptCash(double dMoney) override;
};double CashNormal::AcceptCash(double dMoney)
{return dMoney;
}
class CashRebate :public CashSuper
{
public:CashRebate(double dMoneyRebate);// 通过 CashSuper 继承double AcceptCash(double dMoney) override;
private:double m_dMoneyRebate;
};CashRebate::CashRebate(double dMoneyRebate):m_dMoneyRebate(dMoneyRebate)
{
}double CashRebate::AcceptCash(double dMoney)
{return dMoney * m_dMoneyRebate;
}
class CashReturn :public CashSuper
{
public:CashReturn(double dMoneyCondition, double dMoneyReturn);// 通过 CashSuper 继承double AcceptCash(double dMoney) override;
private:double m_dMoneyCondition;double m_dMoneyReturn;
};CashReturn::CashReturn(double dMoneyCondition, double dMoneyReturn):m_dMoneyCondition(dMoneyCondition), m_dMoneyReturn(dMoneyReturn)
{
}double CashReturn::AcceptCash(double dMoney)
{if (fabs(m_dMoneyCondition) < 1e-6)return dMoney;return dMoney - floor(dMoney / m_dMoneyCondition) * m_dMoneyReturn;
}

- 上下文类(Context):上下文类是使用算法的角色,可以在解决不同具体的问题时实例化不同的具体策略类对象

class CashSuper;
class Context
{
public:Context(CashType eCashType);double GetResult(double dMoney);
private:std::shared_ptr<CashSuper> m_spCashSuper;
};Context::Context(CashType eCashType)
{switch (eCashType){case NORMAL:m_spCashSuper = std::make_shared<CashNormal>();break;case REBATE:m_spCashSuper = std::make_shared<CashRebate>(0.8);break;case RETURN:m_spCashSuper = std::make_shared<CashReturn>(300.0, 100.0);break;default:m_spCashSuper = std::make_shared<CashNormal>();break;}
}double Context::GetResult(double dMoney)
{return m_spCashSuper->AcceptCash(dMoney);
}

3. 用法

    std::shared_ptr<Context> spCashNormalContext = std::make_shared<Context>(CashType::NORMAL);std::shared_ptr<Context> spCashRebateContext = std::make_shared<Context>(CashType::REBATE);std::shared_ptr<Context> spCashReturnContext = std::make_shared<Context>(CashType::RETURN);std::cout << spCashNormalContext->GetResult(600) << std::endl;std::cout << spCashRebateContext->GetResult(600) << std::endl;std::cout << spCashReturnContext->GetResult(600) << std::endl;

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.ryyt.cn/news/60914.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈,一经查实,立即删除!

相关文章

三、浅层神经网络

1、神经网络概览什么是神经网络?如下图:神经网络的结构与逻辑回归类似,只是神经网络的层数比逻辑回归多一层,多出来的中间那层称为隐藏层或中间层。从计算上来看,神经网络的正向传播和反向传播比logistic回归多了一次重复的计算。引入新的标签:方括号上标[i]表示当前所处…

数据稀缺条件下的时间序列微分:符号回归(Symbolic Regression)方法介绍与Python示例

时间序列概况在日常生活和专业研究中都很常见。简而言之,时间序列概况是一系列连续的数据点 y(0), y(1), ..., y(t) ,其中时间 t 的点依赖于时间 t-1 的前一个点(或更早的时间点)。 在许多应用中,研究者致力于预测时间序列概况的未来行为。存在各种建模方法。这些模型通常基于过…

windows安装rabbitmq后出现:Error::plugins_dir_does not_exist

安装的路径正常,没有空格中文字符啥的。 环境变量也配置了。原因是:安装otp_win64_24.1.7时没有选择以管理员身份运行。重新卸载安装即可

【python】python入门基础理论+实践,这一篇就够了

简介:第一个hello world print("hello world!");for i in range(10):print(run:,i);import time; time.sleep(10);字符串str 在Python中,加了引号的字符都被认为是字符串! name = "zhangsan"多引号 多引号什么作⽤呢?作⽤就是多⾏字符串必须⽤多引号 me…

Zero-Shot,One-Shot,Few-Shot,In-Context Learning

Zero-Shot,One-Shot,Few-Shot,In-Context Learning https://blog.csdn.net/weixin_44212848/article/details/139902394In-Context Learning定义:In-context learning是一种在不显式微调模型权重的情况下,通过给模型提供相关的上下文信息(例如提示或样本)来实现模型性能…

GoLand 相关设置

GoLand 相关设置 自动导包设置注意:这里要设置成 Global

AutoCAD C# 判断多边形与点的位置关系

书上说,射线法和叉乘法感觉都不完整 下面我分享我写的基于AutoCAD BREP算法var ed = acApp.Application.DocumentManager.MdiActiveDocument.Editor;var peo = new PromptEntityOptions("Select a PolyLine : ");peo.SetRejectMessage("Only PolyLine");…