C++ Primer(第五版) 13.2.2节练习

13.27    引用计数版本的HasPtr:

class HasPtr {
public:
	HasPtr(const string &s = string()): 
		ps(new string(s)), i(0), use(new size_t(1)) {}
	HasPtr(const HasPtr &p):
		ps(new string(*p.ps)), i(p.i), use(p.use) { ++*use; }
	HasPtr& operator=(const HasPtr&);
	~HasPtr();

private:
	string *ps;
	int i;
	size_t *use;	
};

HasPtr&
HasPtr::operator=(const HasPtr &rhs)
{
	++*rhs.use;
	
	if ( --*use == 0 ) {
		delete ps;
		delete use;
	}
	
	ps = rhs.ps;
	i = rhs.i;
	use = rhs.use;
	
	return *this;
}

HasPtr::~HasPtr()
{
	if ( --*use == 0 ) {
		delete ps;
		delete use;
	}
}

 13.28    TreeNode代码设计:

class TreeNode {
friend class BinStrTree;
public:
	TreeNode(): value(""), count(1), left(nullptr), right(nullptr) {}
	TreeNode(string s, TreeNode *lchild = nullptr, TreeNode *rchild = nullptr):
		value(s), count(1), left(lchild), right(nullptr) { 
			cout << "construct " << endl;
			right = rchild;
	 	}
	TreeNode(const TreeNode &);
	~TreeNode();
	void print_info();
private:
	void CopyTree(void);
	int ReleaseTree(void);
	string value;
	int count;
	TreeNode *left;
	TreeNode *right;
};

void
TreeNode::CopyTree(void)
{
	cout << "copytree " << value << endl;
	if (left)
		left->CopyTree();
	if (right)
		right->CopyTree();
	++count;
}

TreeNode::TreeNode(const TreeNode &tn):
	value(tn.value), count(1), left(tn.left), right(tn.right)
{
	if (left)
		left->CopyTree();
	if (right)
		right->CopyTree();
}

int
TreeNode::ReleaseTree(void)
{
	cout << "release " << value << " " << count << endl;
	if (left) {
		if (!left->ReleaseTree())
			delete left;
	}
	if (right) {
		if (!right->ReleaseTree())
			delete right;
	}
	--count;
	
	return count;
}

TreeNode::~TreeNode()
{
	if (count)
		ReleaseTree();
}

BinStrTree代码设计(需要使用TreeNode类的一些成员):

class BinStrTree {
public:
	BinStrTree(): root(nullptr) {}
	BinStrTree(TreeNode *t = nullptr): root(t) {}
	BinStrTree(const BinStrTree &);
	~BinStrTree();
private:
	TreeNode *root;
};

BinStrTree::BinStrTree(const BinStrTree &bst):
	root(bst.root)
{
	root->CopyTree();
}


BinStrTree::~BinStrTree()
{
	if (!root->ReleaseTree())
		delete root;
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值