组合模式 详解

组合模式

简介: 将对象组合成树形结构以表示"部分-整体"的层次结构, 使得用户对单个对象和组合对象的使用具有一致性.

组合模式也是一种结构类型的模式.看简介比较容易理解, 毕竟树形结构是数据结构必修的, 我们仍然举个例子方便理解

以公司的组织架构为例
公司 - 部门 - 员工

其中员工是叶子节点, 公司和部门是树枝节点
代码

cpp 复制代码
class Node
{
private:
	string name;
public:
	Node(string s) : name(s) {};
	string get_name() { return name; };
	virtual void display() = 0;
	virtual void add_node(Node* n) = 0;
};


class Leaf : public Node
{
public:
	Leaf(string s) : Node(s) {};
	void add_node(Node* n) override
	{
		cout << "leaf node can not add node" << endl;
	}
	void display()
	{
		cout << get_name() << endl;
	}
};


class Branch : public Node
{
private:
	vector<Node*> nodes;
public:
	Branch(string s) : Node(s) {};
	void add_node(Node* n) override
	{
		nodes.push_back(n);
	}
	void display() override
	{
		cout << get_name() << endl;
		for (Node* m : nodes)
			m->display();
	}
};


int main()
{
	Node* b = new Branch("公司");
	Node* b1 = new Branch("__研发部");
	Node* b2 = new Branch("__营销部");
	Node* b3 = new Leaf("____小明");
	Node* b4 = new Leaf("____小强");
	Node* b5 = new Leaf("____小刚");
	b->add_node(b1);
	b->add_node(b2);
	b1->add_node(b3);
	b2->add_node(b4);
	b2->add_node(b5);

	b->display();
	return 0;
}

执行结果

相关推荐
仰泳的熊猫5 小时前
题目2570:蓝桥杯2020年第十一届省赛真题-成绩分析
数据结构·c++·算法·蓝桥杯
Thera7779 小时前
C++ 高性能时间轮定时器:从单例设计到 Linux timerfd 深度优化
linux·开发语言·c++
君义_noip10 小时前
信息学奥赛一本通 1952:【10NOIP普及组】三国游戏 | 洛谷 P1199 [NOIP 2010 普及组] 三国游戏
c++·信息学奥赛·csp-s
旖-旎10 小时前
二分查找(x的平方根)(4)
c++·算法·二分查找·力扣·双指针
顶点多余11 小时前
使用C/C++语言链接Mysql详解
数据库·c++·mysql
汉克老师11 小时前
GESP2026年3月认证C++四级( 第二部分判断题(1-10))
c++·指针·函数重载·文件操作·数组·gesp4级·gesp四级
khddvbe11 小时前
C++并发编程中的死锁避免
开发语言·c++·算法
wWYy.12 小时前
STL:list
开发语言·c++
小比特_蓝光13 小时前
vector模拟实现
c++
咱就是说不配啊13 小时前
3.19打卡day33
数据结构·c++·算法