PTA-6-45 工厂设计模式-运输工具

题目如下:

工厂类用于根据客户提交的需求生产产品(火车、汽车或拖拉机)。火车类有两个子类属性:车次和节数。拖拉机类有1个子类方法耕地,方法只需简单输出"拖拉机在耕地"。为了简化程序设计,所有类的运输方法只需显示"。。。开始进行货物运输。"

需要编写Motor接口的子类:

三个子类Train、Car和Tractor,实现接口Motor,并覆写transport()方法。

需要编写工厂类Factory:

设计一个工厂类Factory,包含一个createMotor(String name)方法,此方法返回值为接口Motor的子类实例对象。

已有的车接口定义如下:

java 复制代码
interface Motor
{
    public static float power=100;
    public static float carrier=100;
    public void transport();
}

已有的Main类定义:

java 复制代码
/* 请在这里填写答案 */

public class Main
{
    public static void main(String args[]){     
      Scanner scan=new Scanner(System.in);
      String name;
      name=scan.next();
      Motor m=Factory.createMotor(name);
      if(m==null)
            System.out.println("没有此类车。");
      else
          m.transport();
    }
}

根据题目要求,代码实现如下:

java 复制代码
class Train implements Motor {
	int number;
	int pitch;
	@Override
	public void transport() {
		System.out.println("车次为30,节数为:20的火车开始进行货物运输。");
	}	
}

class Car implements Motor {
	@Override
	public void transport() {
		System.out.println("汽车开始进行货物运输。");
	}	
}

class Tractor implements Motor {
	public void work() {
		System.out.println("拖拉机在耕地");
	}
	@Override
	public void transport() {
        work();
		System.out.println("拖拉机开始进行货物运输。");
	}	
}

class Factory {
	public static Motor createMotor(String name) {
		if(name.equalsIgnoreCase("火车"))
			return new Train();
		else if(name.equalsIgnoreCase("汽车"))
			return new Car();
		else if(name.equalsIgnoreCase("拖拉机"))
			return new Tractor();
		else
			return null;
	}
}

以上就是 PTA-6-45 工厂设计模式-运输工具的全部内容了,希望能对你有所帮助!

相关推荐
空空潍几秒前
hot100-合并区间(day14)
c++·算法·leetcode
橘颂TA2 分钟前
【剑斩OFFER】算法的暴力美学——力扣 675 题:为高尔夫比赛砍树
数据结构·算法·c·结构与算法
rit84324993 分钟前
UVE算法提取光谱特征波长的MATLAB实现与应用
开发语言·算法·matlab
是娇娇公主~3 分钟前
算法——【最大子数组和】
数据结构·c++·算法
tkevinjd5 分钟前
力扣hot100-283移动零(盲人拉屎)
算法·leetcode
o(╥﹏╥)7 分钟前
Learn how Gen AI 学习笔记
人工智能·笔记·学习
Coder_Boy_7 分钟前
基于SpringAI的在线考试系统-教学管理与用户管理模块联合回归测试文档
java·前端·数据库·人工智能·spring boot
Knight_AL7 分钟前
一文讲透 Java 中transient的用处(结合 Flink 理解)
java·python·flink
阿蒙Amon8 分钟前
C#每日面试题-简述反射
开发语言·面试·c#
POLITE39 分钟前
Leetcode 94. 二叉树的中序遍历 104. 二叉树的最大深度 226. 翻转二叉树 101. 对称二叉树 (Day 13)
算法·leetcode·职场和发展