c++沉思录第十章的例子

2023-12-06 10:19
文章标签 c++ 第十章 例子 沉思

本文主要是介绍c++沉思录第十章的例子,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

关于虚函数和纯虚函数的知识需要我们好好注意。
#ifndef NEWPICTURE_H
#define NEWPICTURE_H
#include<iostream>
using namespace std;
class P_Node
{friend class Picture;
protected:P_Node();virtual ~P_Node(){};virtual int width()const=0;virtual int height()const=0;	virtual void display(ostream &, int, int)const=0;int max(int x, int y)const { return x > y ? x : y; }void pad(ostream & os, int x, int y)const ;
private:int use;
};
class Picture
{friend class String_Pic;friend class Frame_Pic;friend class Hcat_Pic;friend class Vcat_Pic;
public:Picture();Picture(const char * const *, int);Picture(const Picture &);~Picture();Picture & operator =(const Picture &);P_Node * p;Picture(P_Node * m);int height()const;int width()const;void display(ostream &, int, int)const;friend ostream & operator <<(ostream & os, const Picture & p);friend Picture frame(const Picture & p);friend Picture operator & (const Picture & p, const Picture & q);friend Picture operator | (const Picture & p, const Picture & q);
};
class String_Pic :public P_Node
{friend class Picture;String_Pic(const char* const * arr, int n);~String_Pic();char** data;int size;int height()const;int width()const;void display(ostream &, int, int)const;
};class Frame_Pic :public P_Node
{friend Picture frame(const Picture &);int height()const;int width()const;void display(ostream &, int, int)const;Frame_Pic(const Picture &);Picture p;
};class Vcat_Pic :public P_Node
{friend Picture operator &(const Picture & n, const Picture & m);Vcat_Pic(const Picture & n, const Picture & m);int height()const;int width()const;void display(ostream &, int, int)const;Picture top, bottom;
};class Hcat_Pic :public P_Node
{friend Picture operator |(const Picture & n, const Picture & m);Hcat_Pic(const Picture & n, const Picture & m);int height()const;int width()const;void display(ostream &, int, int)const;Picture left,right;
};Picture::Picture(const Picture & m) :p(m.p)
{m.p->use++;
}
Picture::Picture(P_Node * m) : p(m){}
Picture::~Picture()
{if (--p->use == 0)delete p;
}
Picture& Picture::operator=(const Picture & q)
{q.p->use++;if (--p->use == 0)delete p;p = q.p;return *this;
}
int Picture::height()const{ return p->height(); }
int Picture::width()const { return p->width(); }
void Picture::display(ostream & os, int n, int m)const
{p->display(os, n, m);
}
Picture::Picture(const char* const * arr, int n) :p(new String_Pic(arr, n)){}
P_Node::P_Node() :use(1){}String_Pic::String_Pic(const char * const * arr, int n)
: data(new char*[n]), size(n)
{for (int i = 0; i < n; ++i){data[i] = new char[strlen(arr[i]) + 1];strcpy_s(data[i],strlen(arr[i])+1,arr[i]);}
}
String_Pic::~String_Pic()
{for (int i = 0; i < size; ++i)delete[]data[i];delete[]data;}
int String_Pic::height()const{ return size; }
int String_Pic::width()const
{int n = 0;for (int i = 0; i < size; ++i)n = max(n, strlen(data[i]));return n;
}void String_Pic::display(ostream & os, int row, int width)const
{int start = 0;if (row >= 0 && row < height()){os << data[row];start = strlen(data[row]);}pad(os, start, width);
}
int Frame_Pic::height()const{ return p.height() + 2; }
int Frame_Pic::width()const{ return p.width() + 2; }
void Frame_Pic::display(ostream& os, int row, int wd)const
{if (row < 0 || row >= height()){pad(os, 0, wd);}else{if ( 0 == row  || row == height() - 1){os << "+";int i = p.width();while (--i >= 0)os << "-";os << "+";}else{os << "|";p.display(os, row - 1, p.width());os << "|";}pad(os, width(), wd);}
}
Frame_Pic::Frame_Pic(const Picture & m) :p(m){}
Picture frame(const Picture & m)
{return new Frame_Pic(m);
}
Vcat_Pic::Vcat_Pic(const Picture & t, const Picture & b) : top(t), bottom(b){}
Hcat_Pic::Hcat_Pic(const Picture & l, const Picture & r) : left(l),right(r){}
Picture operator &(const Picture & n, const Picture & m)
{return new Vcat_Pic(n, m);
}
Picture operator |(const Picture & n, const Picture & m)
{return new Hcat_Pic(n, m);
}
int Vcat_Pic::height()const{ return top.height() + bottom.height(); }
int Vcat_Pic::width()const{ return max(top.width(), bottom.width()); }
int Hcat_Pic::height()const{ return max(left.height(), right.height()); }
int Hcat_Pic::width()const{ return left.width()+ right.width(); }
void Vcat_Pic::display(ostream& os, int row, int wd)const
{if (row >= 0 && row < top.height())top.display(os, row, wd);else{if (row < top.height() + bottom.height())bottom.display(os, row - top.height(), wd);elsepad(os, 0, wd);}
}
void Hcat_Pic::display(ostream & os, int row, int wd)const
{left.display(os, row, left.width());right.display(os, row, right.width());pad(os, width(), wd);
}
void P_Node::pad(ostream & os, int x, int y)const
{for (int i = x; i < y; ++i)os << " ";
}ostream & operator <<(ostream & os, const Picture & p)
{int ht = p.height();for (int i = 0; i < ht; ++i){	p.display(os, i, 0); os << endl;}return os;
}
#endif
#include"NewPicture.h"
#include<iostream>
using namespace std;
int main()
{char * init[] = { "Summer", "love", "Xieweizhong" };Picture p(init, 3);cout << p << endl;cout << frame((p | frame(p)) | (p | frame(p))) << endl;cout << frame((p & frame(p)) | (p | frame(p))) << endl;cout << frame((p | frame(p)) | (p & frame(p))) << endl;cout << frame((p & frame(p)) | (p & frame(p))) << endl;cout << frame((p | frame(p)) & (p | frame(p))) << endl;cout << frame((p & frame(p)) & (p | frame(p))) << endl;cout << frame((p | frame(p)) & (p & frame(p))) << endl;cout << frame((p & frame(p)) & (p & frame(p))) << endl;return 0;
}


这篇关于c++沉思录第十章的例子的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/461472

相关文章

使用C++实现链表元素的反转

《使用C++实现链表元素的反转》反转链表是链表操作中一个经典的问题,也是面试中常见的考题,本文将从思路到实现一步步地讲解如何实现链表的反转,帮助初学者理解这一操作,我们将使用C++代码演示具体实现,同... 目录问题定义思路分析代码实现带头节点的链表代码讲解其他实现方式时间和空间复杂度分析总结问题定义给定

C++初始化数组的几种常见方法(简单易懂)

《C++初始化数组的几种常见方法(简单易懂)》本文介绍了C++中数组的初始化方法,包括一维数组和二维数组的初始化,以及用new动态初始化数组,在C++11及以上版本中,还提供了使用std::array... 目录1、初始化一维数组1.1、使用列表初始化(推荐方式)1.2、初始化部分列表1.3、使用std::

C++ Primer 多维数组的使用

《C++Primer多维数组的使用》本文主要介绍了多维数组在C++语言中的定义、初始化、下标引用以及使用范围for语句处理多维数组的方法,具有一定的参考价值,感兴趣的可以了解一下... 目录多维数组多维数组的初始化多维数组的下标引用使用范围for语句处理多维数组指针和多维数组多维数组严格来说,C++语言没

c++中std::placeholders的使用方法

《c++中std::placeholders的使用方法》std::placeholders是C++标准库中的一个工具,用于在函数对象绑定时创建占位符,本文就来详细的介绍一下,具有一定的参考价值,感兴... 目录1. 基本概念2. 使用场景3. 示例示例 1:部分参数绑定示例 2:参数重排序4. 注意事项5.

使用C++将处理后的信号保存为PNG和TIFF格式

《使用C++将处理后的信号保存为PNG和TIFF格式》在信号处理领域,我们常常需要将处理结果以图像的形式保存下来,方便后续分析和展示,C++提供了多种库来处理图像数据,本文将介绍如何使用stb_ima... 目录1. PNG格式保存使用stb_imagephp_write库1.1 安装和包含库1.2 代码解

C++实现封装的顺序表的操作与实践

《C++实现封装的顺序表的操作与实践》在程序设计中,顺序表是一种常见的线性数据结构,通常用于存储具有固定顺序的元素,与链表不同,顺序表中的元素是连续存储的,因此访问速度较快,但插入和删除操作的效率可能... 目录一、顺序表的基本概念二、顺序表类的设计1. 顺序表类的成员变量2. 构造函数和析构函数三、顺序表

使用C++实现单链表的操作与实践

《使用C++实现单链表的操作与实践》在程序设计中,链表是一种常见的数据结构,特别是在动态数据管理、频繁插入和删除元素的场景中,链表相比于数组,具有更高的灵活性和高效性,尤其是在需要频繁修改数据结构的应... 目录一、单链表的基本概念二、单链表类的设计1. 节点的定义2. 链表的类定义三、单链表的操作实现四、

使用C/C++调用libcurl调试消息的方式

《使用C/C++调用libcurl调试消息的方式》在使用C/C++调用libcurl进行HTTP请求时,有时我们需要查看请求的/应答消息的内容(包括请求头和请求体)以方便调试,libcurl提供了多种... 目录1. libcurl 调试工具简介2. 输出请求消息使用 CURLOPT_VERBOSE使用 C

C++实现获取本机MAC地址与IP地址

《C++实现获取本机MAC地址与IP地址》这篇文章主要为大家详细介绍了C++实现获取本机MAC地址与IP地址的两种方式,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 实际工作中,项目上常常需要获取本机的IP地址和MAC地址,在此使用两种方案获取1.MFC中获取IP和MAC地址获取

C/C++通过IP获取局域网网卡MAC地址

《C/C++通过IP获取局域网网卡MAC地址》这篇文章主要为大家详细介绍了C++如何通过Win32API函数SendARP从IP地址获取局域网内网卡的MAC地址,感兴趣的小伙伴可以跟随小编一起学习一下... C/C++通过IP获取局域网网卡MAC地址通过win32 SendARP获取MAC地址代码#i