设计模式练习(二) 简单工厂模式

设计模式练习(二) 简单工厂模式

题目描述

小明家有两个工厂,一个用于生产圆形积木,一个用于生产方形积木,请你帮他设计一个积木工厂系统,记录积木生产的信息。

输入描述

输入的第一行是一个整数 N(1 ≤ N ≤ 100),表示生产的次数。

接下来的 N 行,每行输入一个字符串和一个整数,字符串表示积木的类型。积木类型分为 "Circle" 和 "Square" 两种。整数表示该积木生产的数量

输出描述

对于每个积木,输出一行字符串表示该积木的信息。

输入示例
复制代码
3
Circle 1
Square 2
Circle 1
输出示例
复制代码
Circle Block
Square Block
Square Block
Circle Block

code:

cc 复制代码
#include <iostream>
#include <vector>
#include <string>
#include <map>
#include <memory>
 
using namespace std;
 
class Block
{
public:
    virtual ~Block() {}
    virtual std::string GetBlockInfo() const = 0;
};
 
class CircleBlock : public Block
{
public:
    std::string GetBlockInfo() const override
    {
        return "Circle Block";
    }
};
 
class SquareBlock : public Block
{
public:
    std::string GetBlockInfo() const override
    {
        return "Square Block";
    }
};
 
class BlockFactory
{
public:
    static std::unique_ptr<Block> CreateBlock(const std::string &type)
    {
        if (type == "Circle")
        {
            return std::make_unique<CircleBlock>();
        }
        else if (type == "Square")
        {
            return std::make_unique<SquareBlock>();
        }
        return nullptr;
    }
};
 
int main()
{
    int N;
    std::cin >> N;
    for (int i = 0; i < N; ++i)
    {
        std::string type;
        int quantity;
        std::cin >> type >> quantity;
 
        for (int j = 0; j < quantity; ++j)
        {
            std::unique_ptr<Block> block = BlockFactory::CreateBlock(type);
            if (block)
            {
                std::cout << block->GetBlockInfo() << std::endl;
            }
        }
    }
    return 0;
}

工程模式是创建模式

可以看到积木是不变的,为一个接口;其变化的是方形积木和圆形积木,是积木接口的具体实现

开闭原则:对扩展开放,修改关闭;不修改已有代码,灵活地增加新的产品类

相关推荐
漫随流水14 分钟前
c++编程:说反话(1009-PAT乙级)
数据结构·c++·算法
计算机安禾28 分钟前
【数据结构与算法】第23篇:树、森林与二叉树的转换
c语言·开发语言·数据结构·c++·线性代数·算法·矩阵
ab12376844 分钟前
C++ size() 与 length() 核心笔记
开发语言·c++·笔记
苏宸啊1 小时前
哈希表开放定址法增删改查简单实现
数据结构·c++
比昨天多敲两行2 小时前
C++ map和set的使用
开发语言·c++
君鼎2 小时前
C++11 新特性全面总结
c++
6Hzlia3 小时前
【Hot 100 刷题计划】 LeetCode 76. 最小覆盖子串 | C++ 滑动窗口题解
c++·算法·leetcode
像素猎人3 小时前
蓝桥杯OJ2049蓝桥勇士【动态规划】【dp[n]不是符合题意的答案,只是以an结尾的子问题的答案】
c++·算法·蓝桥杯·动态规划·区间dp
xiaoye-duck3 小时前
《算法题讲解指南:动态规划算法--子数组系列》--21.乘积最大子数组,22.乘积为正数的最长子数组
c++·算法·动态规划
计算机安禾3 小时前
【数据结构与算法】第24篇:哈夫曼树与哈夫曼编码
c语言·开发语言·数据结构·c++·算法·visual studio