#include<iostream> #include<cstring> using namespace std; class PersonFactory { int id; char name[50]; int age; public: PersonFactory(int i = 0, char * nm = 0, int a = 15);//i:id;nm:name;a:age virtual ~PersonFactory() {}; virtual void PrintInfo() { cout << id << endl; cout << name << endl; cout << age << endl; }; PersonFactory * CreateStudent(int id, char *name, int age, int grade); PersonFactory * CreateTeacher(int id, char *name, int age, char *department); }; int main() { PersonFactory vn; PersonFactory *ps,*pt; int id,age,grade; char name[50],department[50]; cin>>id>>name>>age>>department; ps=vn.CreateTeacher (id,name,age,department); ps->PrintInfo (); cin>>id>>name>>age>>grade; ps=vn.CreateStudent (id,name,age,grade); ps->PrintInfo (); return 0; }请依据这段代码,将其补全完成上个问题将上个问题

时间: 2023-06-15 14:06:47 浏览: 51
以下是补全后的代码: ``` #include<iostream> #include<cstring> using namespace std; class PersonFactory { int id; char name[50]; int age; public: PersonFactory(int i = 0, char * nm = 0, int a = 15) { id = i; strcpy(name, nm); age = a; } virtual ~PersonFactory() {}; virtual void PrintInfo() { cout << id << endl; cout << name << endl; cout << age << endl; }; class Student : public PersonFactory { int grade; public: Student(int i, char *nm, int a, int g) : PersonFactory(i, nm, a) { grade = g; } void PrintInfo() { PersonFactory::PrintInfo(); cout << grade << endl; } }; class Teacher : public PersonFactory { char department[50]; public: Teacher(int i, char *nm, int a, char *dp) : PersonFactory(i, nm, a) { strcpy(department, dp); } void PrintInfo() { PersonFactory::PrintInfo(); cout << department << endl; } }; PersonFactory * CreateStudent(int id, char *name, int age, int grade) { return new Student(id, name, age, grade); } PersonFactory * CreateTeacher(int id, char *name, int age, char *department) { return new Teacher(id, name, age, department); } }; int main() { PersonFactory vn; PersonFactory *ps,*pt; int id,age,grade; char name[50],department[50]; cin>>id>>name>>age>>department; pt=vn.CreateTeacher (id,name,age,department); pt->PrintInfo (); cin>>id>>name>>age>>grade; ps=vn.CreateStudent (id,name,age,grade); ps->PrintInfo (); return 0; } ``` 这个程序使用了工厂模式,其中 PersonFactory 类是一个抽象基类,包含了一个虚函数 PrintInfo(),用于打印人员的信息。它有两个派生类,分别是 Student 和 Teacher,分别表示学生和教师。在 PersonFactory 类中,定义了两个工厂方法 CreateStudent() 和 CreateTeacher(),用于创建学生和教师对象。在 main() 函数中,首先调用 CreateTeacher() 方法创建一个教师对象,然后调用 PrintInfo() 方法打印出教师的信息;接着调用 CreateStudent() 方法创建一个学生对象,然后调用 PrintInfo() 方法打印出学生的信息。

相关推荐

Person人员类包含私有成员数据姓名(char name[40])、性别(char sex[3])和年龄(int age)。 Teacher教师类由Person人员类公有派生而来,包含私有成员数据职称(char title[40])和工资(int pay),其姓名、性别和年龄等数据从Person人员类继承而来。 完成Person人员类和Teacher教师类的设计,使得主程序能够正确运行。#include<iostream> #include<cstring> using namespace std; //你提交的代码在这里 int main() { char name[40],sex[3],title[40]; int age,pay; cin>>name>>sex>>age>>title>>pay; Person p1; cout<<"Person #1:"; p1.Show(); Person p2(name,sex,age); cout<<"Person #2:"; p2.Show(); Teacher t1; cout<<"Teacher #1:"; t1.Show(); Teacher t2(name,sex,age,title,pay); cout<<"Teacher #2:"; t2.Show(); Teacher t3(p2,title,pay); cout<<"Teacher #3:"; t3.Show(); Teacher t4(title,pay); cout<<"Teacher #4:"; t4.Show(); Teacher t5(p2); cout<<"Teacher #5:"; t5.Show(); return 0; },当输入张三 男 35 副教授 3000时,要输出Function #1 is called! Person #1:NAME:Unknown SEX:No AGE:0 Function #3 is called! Function #2 is called! Person #2:NAME:张三 SEX:男 AGE:35 Function #3 is called! Function #1 is called! Function #4 is called! Teacher #1:NAME:Unknown SEX:No AGE:0 TITLE:NONE PAY:0 Function #9 is called! Function #2 is called! Function #5 is called! Teacher #2:NAME:张三 SEX:男 AGE:35 TITLE:副教授 PAY:3000 Function #9 is called! Function #6 is called! Teacher #3:NAME:张三 SEX:男 AGE:35 TITLE:副教授 PAY:3000 Function #9 is called! Function #1 is called! Function #7 is called! Teacher #4:NAME:Unknown SEX:No AGE:0 TITLE:副教授 PAY:3000 Function #9 is called! Function #8 is called! Teacher #5:NAME:张三 SEX:男 AGE:35 TITLE:NONE PAY:0 Function #9 is called!,给出相应c++代码

#include<iostream> #include<cstring> using namespace std; class Person { private:char name[40]; char sex[3]; int age; public: Person() { strcpy(name,"Unknown"); strcpy(sex,"No"); age=0; cout<<"Function #1 is called!"<<endl; } Person(const char na[40], const char se[3], int a) { strcpy(name, na); strcpy(sex, se); age = a; cout << "Function #2 is called!" << endl; } Person(const Person& p) { strcpy(name,p.name); strcpy(sex,p.sex); age=p.age; } ~Person(){}; void Show(); void Show2(); }; void Person::Show() { cout<<"NAME:"<<name<<" "<<"SEX:"<<sex<<" "<<"AGE:"<<age<<endl; cout<<"Function #3 is called!"<<endl; } void Person::Show2() { cout<<"NAME:"<<name<<" "<<"SEX:"<<sex<<" "<<"AGE:"<<age<<" "; } class Teacher:public Person { private:char title[40]; int pay; public: Teacher():Person() { strcpy(title,"NONE"); pay=0; cout<<"Function #4 is called!"<<endl; } Teacher(char *na,char *se,int a,char *t,int p):Person(na,se,a) { strcpy(title,t); pay=p; cout<<"Function #5 is called!"<<endl; } Teacher(const Person& p,char *t,int pa):Person(p) { strcpy(title,t); pay=pa; cout<<"Function #6 is called!"<<endl; } Teacher(char *t,int p):Person() { strcpy(title,t); pay=p; cout<<"Function #7 is called!"<<endl; } Teacher(const Teacher& t):Person(t) { strcpy(title,t.title); pay=t.pay; } Teacher(const Person& p):Person(p){ strcpy(title,"NONE"); pay=0; cout<<"Function #8 is called!"<<endl; } ~Teacher(){}; void Show(); }; void Teacher::Show() { Person::Show2(); cout<<""<<"TLTLE:"<<title<<" "<<"PAY:"<>name>>sex>>age>>title>>pay; Person p1; cout<<"Person #1:"; p1.Show(); Person p2(name,sex,age); cout<<"Person #2:"; p2.Show(); Teacher t1; cout<<"Teacher #1:"; t1.Show(); Teacher t2(name,sex,age,title,pay); cout<<"Teacher #2:"; t2.Show(); Teacher t3(p2,title,pay); cout<<"Teacher #3:"; t3.Show(); Teacher t4(title,pay); cout<<"Teacher #4:"; t4.Show(); Teacher t5(p2); cout<<"Teacher #5:"; t5.Show(); return 0; },优化这段代码

最新推荐

recommend-type

概率论与数理统计试卷三套(含答案)

2020-2021年概率论与数理统计试卷
recommend-type

“人力资源+大数据+薪酬报告+涨薪调薪”

人力资源+大数据+薪酬报告+涨薪调薪,在学习、工作生活中,越来越多的事务都会使用到报告,通常情况下,报告的内容含量大、篇幅较长。那么什么样的薪酬报告才是有效的呢?以下是小编精心整理的调薪申请报告,欢迎大家分享。相信老板看到这样的报告,一定会考虑涨薪的哦。
recommend-type

伊坂幸太郎21册合集.mobi

伊坂幸太郎21册合集.mobi
recommend-type

STC89C51 简单时钟

STC89C51 简单时钟,叫你从基础开始学习单片机,
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

MATLAB归一化方法大比拼:5种方法,哪种最适合你的数据?

![MATLAB归一化方法大比拼:5种方法,哪种最适合你的数据?](https://www.finebi.com/wp-content/uploads/2019/11/FineBI%E8%A1%8C%E4%B8%9A%E9%A9%BE%E9%A9%B6%E8%88%B1-1024x510.png) # 1. MATLAB归一化概述 归一化是一种数据预处理技术,用于将数据缩放到特定范围内,从而消除不同特征之间的尺度差异。在MATLAB中,有各种归一化方法可用于不同类型的数据和应用程序。 归一化的主要目的是: - 提高模型的训练效率和准确性,通过消除特征之间的尺度差异,使模型能够更有效地学习
recommend-type

failed to register layer: ApplyLayer exit status 1 stdout: stderr: archive/tar: invalid tar header

很抱歉听到这个问题。这个错误通常是由于Docker镜像损坏或Docker存储库中缺少所需的图层引起的。您可以尝试以下几种方法来解决这个问题: 1. 清理Docker镜像和容器:使用命令“docker system prune”清理不再使用的Docker对象。 2. 检查Docker存储库:确保您正在使用可靠的Docker存储库,并检查是否存在所有必需的图层。 3. 重新下载Docker镜像:如果您确定问题是由于损坏的Docker镜像引起的,则可以尝试重新下载Docker镜像。 4. 更新Docker版本:如果您使用的是旧版Docker,则可能会出现此问题。尝试更新到最新版本的Docke
recommend-type

Linux系统常用操作命令大全手册

附件是Linux系统常用操作命令大全手册,是 markdown格式,其中覆盖了Linux系统管理、文件操作、网络配置等多个方面,都是日常工作中非常常用的命令,欢迎大家下载学习使用!
recommend-type

"互动学习:行动中的多样性与论文攻读经历"

多样性她- 事实上SCI NCES你的时间表ECOLEDO C Tora SC和NCESPOUR l’Ingén学习互动,互动学习以行动为中心的强化学习学会互动,互动学习,以行动为中心的强化学习计算机科学博士论文于2021年9月28日在Villeneuve d'Asq公开支持马修·瑟林评审团主席法布里斯·勒菲弗尔阿维尼翁大学教授论文指导奥利维尔·皮耶昆谷歌研究教授:智囊团论文联合主任菲利普·普雷教授,大学。里尔/CRISTAL/因里亚报告员奥利维耶·西格德索邦大学报告员卢多维奇·德诺耶教授,Facebook /索邦大学审查员越南圣迈IMT Atlantic高级讲师邀请弗洛里安·斯特鲁布博士,Deepmind对于那些及时看到自己错误的人...3谢谢你首先,我要感谢我的两位博士生导师Olivier和Philippe。奥利维尔,"站在巨人的肩膀上"这句话对你来说完全有意义了。从科学上讲,你知道在这篇论文的(许多)错误中,你是我可以依
recommend-type

MATLAB归一化实战指南:从零到一,轻松提升模型性能

![MATLAB归一化实战指南:从零到一,轻松提升模型性能](https://pic1.zhimg.com/80/v2-fd366800ef0bdf29c804ce25c0276778_1440w.webp) # 1. 归一化的理论基础** 归一化是一种数据预处理技术,旨在将数据缩放到特定范围内,通常是[0, 1]或[-1, 1]。通过归一化,可以消除数据量纲上的差异,使不同特征具有可比性,从而提高机器学习模型的性能。 归一化背后的基本原理是,在训练机器学习模型时,模型的学习过程会受到数据分布的影响。如果数据分布不均匀,某些特征可能具有较大的值域,而其他特征的值域较小。这会导致模型在训练过