p475.2

//头文件:
class Cd{
private:
char *performers;
char *label;
int selections;
double playtime;
public:
Cd(char *s1, char *s2, int n, double x);
Cd(const Cd & st);
Cd();
virtual ~Cd();
virtual void Report()const;
Cd & operator = (const Cd & st);
}; class Classic : public Cd
{
private:
char *production;
public:
Classic(char *s1 = "nullbody1", char *s2 = "nullbody2", char *s3 = "nullbody3", int n = , double x = );
Classic(const Classic & st);
virtual void Report()const;
virtual ~Classic();
Classic & operator=(const Classic & st);
}; //方法:
#include<iostream>
#include<cstring>
#include"classic.h" using std::cout;
using std::endl; Cd::Cd(char *s1, char *s2, int n, double x){
performers = new char[strlen(s1) + ];
strcpy(performers, s1);
label = new char[strlen(s2) + ];
strcpy(label, s2);
selections = n;
playtime = x;
} Cd::Cd(const Cd & st){
performers = new char[strlen(st.performers) + ];
strcpy(performers, st.performers);
label = new char[strlen(st.performers) + ];
strcpy(label, st.label);
selections = st.selections;
playtime = st.playtime;
} Cd::Cd(){
performers = NULL;
label = NULL;
selections = ;
playtime = ;
} void Cd::Report()const{
cout << "performers: " << performers << endl
<< "label: " << label << endl
<< "selections: " << selections << endl
<< "playtime: " << playtime << endl;
} Cd & Cd::operator = (const Cd & st){
if (this == &st)
return *this;
performers = new char[strlen(st.performers) + ];
strcpy(performers, st.performers);
label = new char[strlen(st.performers) + ];
strcpy(label, st.label);
selections = st.selections;
playtime = st.playtime;
return *this;
} Classic::Classic(char *s1, char *s2, char *s3, int n, double x): Cd(s2, s3, n, x){
production = new char[strlen(s1) + ];
strcpy(production, s1);
} Classic::Classic(const Classic & st): Cd(st){
production = new char[strlen(st.production) + ];
strcpy(production, st.production);
} Cd::~Cd(){
delete[]performers;
delete[]label;
} Classic::~Classic(){
delete[]production;
} void Classic::Report()const{
cout << "production: " << production << endl;
Cd::Report();
} Classic & Classic::operator=(const Classic & st){
if (this == &st)
return *this;
Cd::operator=(st);
production = new char[strlen(st.production) + ];
strcpy(production, st.production);
return *this;
} //驱动:
#include<iostream>
#include<cstdlib>
using namespace std;
#include"classic.h"
void Bravo(const Cd & disk); int main(){
Cd c1("Beatles", "Capitol", , 35.5);
Classic c2 = Classic("piano sonata in B flat", "Alfred Brendel", "Philips", , 57.17);
Cd *pcd = &c1; cout << "using object directly\n";
c1.Report();
c2.Report(); cout << "using type cd *pointer to objects:\n";
pcd->Report();
pcd = &c2;
pcd->Report(); cout << "calling a function with a Cd reference argument:\n";
Bravo(c1);
Bravo(c2);
cout << "testing assignment: ";
Classic copy;
copy = c2;
copy.Report(); system("pause");
return ;
} void Bravo(const Cd & disk){
disk.Report();
}

p475.3

 //头文件:
#include<iostream> #ifndef BASE_H_
#define BASE_H_
class baseABC
{
private:
char *label;
int rating;
public:
baseABC(const char *s1="null", int r = );
baseABC(const baseABC &st);
virtual ~baseABC() = ;
baseABC & operator=(const baseABC &rs);
friend std::ostream & operator<<(std::ostream & os, const baseABC & rs);
}; class baseDMA : public baseABC
{
public:
baseDMA(const char *s1="null", int r = );
baseDMA(const baseDMA &st);
baseDMA & operator=(const baseDMA &rs);
friend std::ostream & operator<<(std::ostream & os, const baseDMA & rs);
}; class lacksDMA : public baseABC
{
private:
enum{COL_LEN=};
char color[COL_LEN];
public:
lacksDMA(const char *pt = "blank", const char *ct = "null", int r = );
lacksDMA(const char *pt, const baseABC & st);
friend std::ostream & operator<<(std::ostream & os, const lacksDMA & st);
}; class hasDMA : public baseABC
{
private:
char *style;
public:
hasDMA(const char *pt = "none", const char *ct = "null", int r = );
hasDMA(const char *ct, const baseABC &st);
hasDMA(const hasDMA &st);
virtual ~hasDMA();
hasDMA & operator=(const hasDMA & st);
friend std::ostream & operator <<(std::ostream &os, const hasDMA &st);
}; #endif //方法:
#include<iostream>
#include<cstring>
#include"classic.h" using std::endl; baseABC::baseABC(const char *s1, int r){
label = new char[strlen(s1) + ];
strcpy(label, s1);
rating = r;
} baseABC::baseABC(const baseABC &st){
label = new char[strlen(st.label) + ];
strcpy(label, st.label);
rating = st.rating;
} baseABC::~baseABC(){
delete[]label;
} baseABC & baseABC::operator=(const baseABC &rs){
if (this == &rs)
return *this;
label = new char[strlen(rs.label) + ];
strcpy(label, rs.label);
rating = rs.rating;
return *this;
} std::ostream & operator<<(std::ostream & os, const baseABC & rs){
os << "label: " << rs.label << endl
<< "rating: " << rs.rating << endl;
return os;
} baseDMA::baseDMA(const char *s1, int r): baseABC(s1, r){
} baseDMA::baseDMA(const baseDMA &st): baseABC(st){
} baseDMA & baseDMA::operator=(const baseDMA &rs){
if (this == &rs)
return *this;
baseABC::operator=(rs);
return *this;
} std::ostream & operator<<(std::ostream & os, const baseDMA & rs){
os << (const baseABC &)rs;
return os;
} lacksDMA::lacksDMA(const char *pt, const char *ct, int r): baseABC(ct, r){
strncpy(color, pt, COL_LEN);
color[COL_LEN - ] = '\0';
} lacksDMA::lacksDMA(const char *pt, const baseABC & st): baseABC(st){
strncpy(color, pt, COL_LEN);
color[COL_LEN - ] = '\0';
} std::ostream & operator<<(std::ostream & os, const lacksDMA & st){
os << (const baseABC &)st<<endl
<<"color: "<<st.color;
return os;
} hasDMA::hasDMA(const char *pt, const char *ct, int r): baseABC(ct, r){
style = new char[strlen(pt) + ];
strcpy(style, pt);
} hasDMA::hasDMA(const char *ct, const baseABC &st): baseABC(st){
style = new char[strlen(ct) + ];
strcpy(style, ct);
} hasDMA::hasDMA(const hasDMA &st): baseABC(st){
style = new char[strlen(st.style) + ];
strcpy(style, st.style);
} hasDMA::~hasDMA(){
delete[]style;
} hasDMA & hasDMA::operator=(const hasDMA & st){
if (this == &st)
return *this;
delete[]style;
baseABC::operator=(st);
style = new char[strlen(st.style) + ];
strcpy(style, st.style);
return *this;
} std::ostream & operator <<(std::ostream &os, const hasDMA &st){
os << (const baseABC &)st<<endl
<<"style: "<< st.style << endl;
return os;
} //驱动:
#include<iostream>
#include<cstdlib>
#include"classic.h" const int CLIENTS = ;
const int LEN = ; int main(){
using namespace std;
int i;
baseABC *pt[CLIENTS]; for (i = ; i < CLIENTS; i++){
char temp[LEN];
cout << "enter the label\n";
cin.get(temp, LEN).get();
int r;
cout << "enter the rating\n";
cin >> r;
while (cin.get() != '\n')
continue;
char kind;
cout << "enter 1/2/3 to choice a model to fit baseDMA/lacksDMA/hasDMA\n";
cin >> kind;
while (cin.get() != '\n')
continue;
if (kind == '')
pt[i] = new baseDMA(temp, r);
else if (kind == ''){
char ar[];
cout << "enter a color\n";
cin.get(ar, ).get();
baseDMA test1(temp, r);
pt[i] = new lacksDMA(ar, test1);
}
else if (kind == ''){
char ptr[];
cout << "enter a style\n";
cin.get(ptr, ).get();
pt[i] = new hasDMA(ptr, temp, r);
}
}
for (i = ; i < CLIENTS; i++)
cout << *pt[i] << endl; system("pause");
return ;
}

c++ primer plus 习题答案(8)的更多相关文章

  1. c++ primer plus 习题答案(1)

    c++ primer plus 习题答案用的是第五版,IDE仍然是vs2013.我只标注了题号,具体的题目找下书上对应内容吧. p110.8 #include<iostream> #inc ...

  2. c++ primer plus 习题答案(7)

    p427.4 //头文件: #include<iostream> #ifndef STACK_H_ #define STACK_H_ typedef unsigned long Item; ...

  3. c++ primer plus 习题答案(6)

    p425.1 #include<iostream> #include<cstring> #include<cstdlib> using namespace std; ...

  4. c++ primer plus 习题答案(5)

    p333.7 #include<iostream> #include<cstring> #include<cstdlib> using namespace std; ...

  5. c++ primer plus 习题答案(4)

    p333.3 #include<iostream> #include<cstdlib> #include<cstring> #include<string&g ...

  6. c++ primer plus 习题答案(3)

    p296.3 #include<iostream> #include<cstdlib> #include<string> #include<cstring&g ...

  7. c++ primer plus 习题答案(2)

    p221.8 #include<iostream> #include<cstdlib> #include<cstring> using namespace std; ...

  8. C++Primer第五版——习题答案目录

    目前正在刷<C++Primer>这本书,会在博客上记录课后习题答案,答案仅供参考. 因为水平有限,如有有误之处,希望大家不吝指教,谢谢! 目录地址 使用的系统为:win 10,编译器:VS ...

  9. 《C++Primer》第五版习题答案--第五章【学习笔记】

    <C++Primer>第五版习题答案--第五章[学习笔记] ps:答案是个人在学习过程中书写,可能存在错漏之处,仅作参考. 作者:cosefy Date: 2020/1/15 第五章:语句 ...

随机推荐

  1. poj1665

    #include <stdio.h> #include <stdlib.h> #define pi 3.1415926 int main() { float dia,tim; ...

  2. Oracle 11g新特性虚拟列分区

    如今有个需求:一个单据表要依照月份来分区.假设是在Oracle 10g上,仅仅能再加一个字段. 在Oracle 11g以后就不一样了.能够用虚拟列处理. SQL> select * from v ...

  3. 【DateStructure】 Charnming usages of Map collection in Java

    When learning the usage of map collection in java, I found serveral beneficial methods that was enco ...

  4. ceph优秀博文

    ceph官方博文: http://ceph.com/community/blog/ rgw根据rgw用户来分pool存放数据 http://cephnotes.ksperis.com/blog/201 ...

  5. SQLite for C#

    slqlite是个轻量级的数据库,是目前较为流行的小型数据库,适用于各个系统..NET自然也是支持的 1.添加2个引用System.Data.SQLite.Linq,System.Data.SQLit ...

  6. 安装 GitStack 提示 80 端口 被 SYSTEM PID4 占用

    任务管理器 - 服务 W3SVC - World Wide Web Publishing Service  停止服务.

  7. ADO知识的运用二(Day 28)

    可能是最近有些沉迷于电视剧了,所以,好多天都没写总结了.我知道这样不好,但又老管不住自己,也许是我自控力太差了吧......呵呵,如果在不写总结,可能以后就会成为习惯了.所以今天要赶紧补上...... ...

  8. 调度器(scheduler)

    调度器(schedule)为游戏提供定时事件和定时调用服务. 调度器(schedule)的功能和事件监听器(eventlistener)的功能有点类似:都是在特定情况下调用某个事先准备好的回调函数. ...

  9. HDU-Billboard-2795(线段树)

    hdu2795 Billboard Time Limit: 20000/8000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Other ...

  10. apache rewrite rule

    http://10.58.104.19:8008/site/833/3f11d2b44b7d3baa2149f26a30f8c68d/b.js?siteid=332323 将一个静态请求转换成一个动态 ...