【设计模式专题之工厂方法模式】2.积木工厂

时间限制:1.000S 空间限制:256MB

题目描述

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

输入描述

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

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

输出描述

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

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

在示例中,积木工厂生产了3块积木,其中有2块是圆形积木,1块是方形积木。根据输入的类型,每块积木的信息被输出到控制台。

java 复制代码
import java.util.ArrayList;
import java.util.List;
import java.util.Scanner;

// 抽象积木接口
interface Block {
    void produce();
}

// 具体圆形积木实现
class CircleBlock implements Block {

    @Override
    public void produce() {
        System.out.println("Circle Block");
    }
}

// 具体方形积木实现
class SquareBlock implements Block {

    @Override
    public void produce() {
        System.out.println("Square Block");
    }
}

// 抽象积木工厂接口
interface BlockFactory {
    Block createBlock();
}

// 具体圆形积木工厂实现
class CircleBlockFactory implements BlockFactory {

    @Override
    public Block createBlock() {
        return new CircleBlock();
    }
}

// 具体方形积木工厂实现
class SquareBlockFactory implements BlockFactory {
    @Override
    public Block createBlock() {
        return new SquareBlock();
    }
}

// 积木工厂系统
class BlockFactorySystem {
    // 添加产品
    private List<Block> blocks = new ArrayList<>();

    // 创建产品
    public void produceBlocks(BlockFactory factory, int quantity) {
        for (int i = 0; i < quantity; i++) {
            Block block = factory.createBlock();
            // 将产品加入集合
            blocks.add(block);
            // 创建产品
            block.produce();
        }
    }

    public List<Block> getBlocks() {
        return blocks;
    }

}

public class Main {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        // 创建积木工厂系统
        BlockFactorySystem blockFactorySystem = new BlockFactorySystem();
        // 读取生产次数
        int productCount = sc.nextInt();
        for (int i = 0; i < productCount; i++) {
            String blockType = sc.next();
            int quantity = sc.nextInt();
            if (blockType.equals("Circle")){
                blockFactorySystem.produceBlocks(new CircleBlockFactory(),quantity);
            } else if (blockType.equals("Square")){
                blockFactorySystem.produceBlocks(new SquareBlockFactory(),quantity);
            }
        }
    }
}
相关推荐
YA33322 分钟前
java基础(六)jvm
java·开发语言
不吃洋葱.1 小时前
左子树之和
算法
JavaArchJourney1 小时前
Java 集合框架
java
金融小师妹1 小时前
基于AI量化模型的比特币周期重构:传统四年规律是否被算法因子打破?
大数据·人工智能·算法
尘民10241 小时前
面试官笑了:线程start() 为什么不能再来一次?
java
会是上一次2 小时前
企业级WEB应用服务器TOMCAT
java·前端·tomcat
数据智能老司机2 小时前
图算法趣味学——最短路径
数据结构·算法·云计算
快去睡觉~2 小时前
力扣109:有序链表转换二叉搜索树
算法·leetcode·链表
是Dream呀3 小时前
YOLOv8深度解析:从架构革新到应用实践
人工智能·算法
Java中文社群3 小时前
抱歉!Java面试标准答案最不重要
java·后端·面试