码迷,mamicode.com
首页 > 编程语言 > 详细

C++:广义表的实现

时间:2015-11-10 14:18:30      阅读:259      评论:0      收藏:0      [点我收藏+]

标签:广义表   结构体   递归   


GeneralList.hpp            

#pragma once

#include<iostream>
#include<string>
using namespace std;

enum NodeType{               //结点类型
	HEAD_TYPE,
	VALUE_TYPE,
	SUB_TYPE,
};

struct GeneralListNode{            //结点的结构体
	NodeType _type;
	GeneralListNode* _next;

	union{
		char _value;
		GeneralListNode* _subLink;
	};
	GeneralListNode(NodeType type = HEAD_TYPE, char value = ‘\0‘)
		:_type(type)
		, _next(NULL){
		if (type == VALUE_TYPE){
			_value = value;
		}
		else if (type == SUB_TYPE)
		{
			_subLink = NULL;
		}
	}
};

class GeneralList{
public:
	GeneralList(const char* str) :_link(NULL){      //构造函数
		_CreateGeneralList(_link, str);
	}
	GeneralList(const GeneralList& gl){             //拷贝构造函数
			_link = _Copy(gl._link);
	}
	GeneralList& operator=(const GeneralList& gl){   //重载函数
		if (this != &gl){
		        _Delete(_link);
			 _Copy(gl._link);
		}
		else
		    return *this;
	}  
	~GeneralList(){                                 //析构函数
		 _Delete(_link);
	}
	
	void Print()                                   //显示函数
	{
		_Print(_link);
		cout << endl;
	}

	int Size(){                        //计算广义表的大小,最外层的元素个数
		GeneralListNode* begin = _link;
		int size = 0;

		if (begin->_type == HEAD_TYPE)
			return 1;
		else{
			while (begin){
				size++;
				begin = begin->_next;
			}
		}
		return size;
	}

	int Depth(){					//计算广义表的深度
		return _Depth(_link);
	}
protected:
	const char* _CreateGeneralList(GeneralListNode*& link, const char*str){  //构造函数的实现
		GeneralListNode* begin = NULL;
		char* compareStr = "()";     //定义检查是否为()的字符串

		while (isspace(*str))          //检查是否有空格
			str++;
		if (*str != ‘(‘){            //检查输入是否合法
			cout << "input illeagle!" << endl;
			exit(-1);
		}

		if (strcmp(str, compareStr) == 0){                    //判断是否为head_type
			GeneralListNode* head = new GeneralListNode(HEAD_TYPE);   //创建结点
			link = head;
			begin = head;
		}

		str++;          //从第一个左括号后开始
		//判断类型,为其创建结点
		while (*str != ‘\0‘){
			if (*str == ‘,‘)
				str++;
			while (isspace(*str))          //检查是否有空格
				str++;
			if (*str == ‘(‘)    {         //如果是sub_type
				GeneralListNode* subNode = new GeneralListNode(SUB_TYPE);
				if (begin == NULL){
					begin = subNode;
					link = begin;
					 str = _CreateGeneralList(begin->_subLink, str);   //递归建立子表
				}
				else{
					begin->_next = subNode;
					begin = begin->_next;
					str = _CreateGeneralList(begin->_subLink, str);
				}
			}
			else if (*str == ‘)‘ && *++str != ‘\0‘){               //递归结束条件
				return str;
			}
			else if (*str != ‘)‘ && *str != ‘\0‘){         //如果是value_type
				GeneralListNode* valueNode = new GeneralListNode(VALUE_TYPE, *str);
				if (begin == NULL){
					begin = valueNode;
					link = begin;
				}
				else{
					begin->_next = valueNode;
					begin = begin->_next;
				}
			}
			str++;
		}
	}

	GeneralListNode* _Copy(GeneralListNode* link){               //拷贝构造的实现
		GeneralListNode* _new = NULL;

		if (link){
			_new = new GeneralListNode(link->_type);             //创建头结点
			_new->_next = link->_next;
			switch (_new->_type)
			{
			case HEAD_TYPE:                                 
				_new->_value = link->_value;
				break;
			case VALUE_TYPE:
				_new->_value = link->_value;
				break;
			case SUB_TYPE:
				_new->_subLink = link->_subLink;
				break;
			default:
				break;
			}
			_new->_next = _Copy(link->_next);                  //递归创建其余结点
		}
		return _new;
	}

	GeneralListNode*  _Delete(GeneralListNode* link){     //析构函数的实现从右到左,从下到上
		GeneralListNode* begin = link;

		if (begin){
			switch (begin->_type){
			case HEAD_TYPE:
				break;
			case VALUE_TYPE:
				_Delete(begin->_next);
				break;
			case SUB_TYPE:
				_Delete(begin->_next);
				_Delete(begin->_subLink);
				break;
			default:
				break;
			}
			delete begin;
		}
		return begin;
	}

	void _Print(GeneralListNode* link){                   //显示函数的实现
		GeneralListNode* begin = link;
		cout << "(";
		while (begin){
			if (begin->_type == HEAD_TYPE){
				cout << ")";
			}
			else if (begin->_type == VALUE_TYPE){
				cout << begin->_value;
				if (begin->_next){
					cout << ",";
				}
				else{
					cout << ")";
				}
			}
			else if (begin->_type == SUB_TYPE){
				_Print(begin->_subLink);
				if (begin->_next){
					cout << ",";
				}
			}
			begin = begin->_next;
		}
	}

	int _Depth(GeneralListNode* link){             //深度的计算,找到子表个数最多
		GeneralListNode* begin = link;
		int depth = 0;
		int max = 0;

		while (begin){
		if (begin->_type == HEAD_TYPE)
			return 1;
		else if (begin->_type == VALUE_TYPE){
			begin = begin->_next;
		}
		else if (begin->_type == SUB_TYPE){
			depth = _Depth(begin->_subLink);
			if (depth > max)
				max = depth;
			begin = begin->_next;
		}
		}
		return max+1;
	}
private:
	GeneralListNode* _link;
};


本文出自 “moLova” 博客,请务必保留此出处http://molova.blog.51cto.com/10594266/1711332

C++:广义表的实现

标签:广义表   结构体   递归   

原文地址:http://molova.blog.51cto.com/10594266/1711332

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!