顺序表的头文件和头文件的实现

注意:1模板类中的函数有const,那么定义此函数时const必须要有

2定义模板类的函数时,template<class ElemType>一定要有class

#ifndef _SQLIST_H_
#define _SQLIST_H_

#include <iostream>
using namespace std;
const DEFAULT_SIZE=10;
enum StatusCode{RANGE_ERROR,SUCCESS,NOT_PRESENT,ENTRY_FOUND,OVER_FLOW};
template<class ElemType>
class SqList
{
protected:

	ElemType *ptr;
	int count;
	int maxSize;
	
	
	void init(int size);
	bool full()const;
	
public:
	SqList(int size=DEFAULT_SIZE);
	virtual ~SqList();
	int length()const;
	bool isEmpty()const;
	void clear();

	StatusCode setElem(int position,const ElemType &e);
	StatusCode getElem(int position,ElemType &e)const;
	StatusCode Insert(int position,const ElemType &e);
	StatusCode Delete(int position,ElemType &e);
	SqList(const SqList<ElemType> &copy);
	SqList<ElemType>& operator = (const SqList<ElemType> &copy);

	void Traverse(void(*visit)(ElemType & ))const;
};

template<class ElemType>
bool SqList<ElemType>::full()const
{
	return count==maxSize;
}

template<class ElemType>
SqList<ElemType>::SqList(int size)

{
	ptr=NULL;
	init(size);
}

template<class ElemType>
void SqList<ElemType>::init(int size)
{
	maxSize=size;
	count=0;
	if(ptr!=NULL)
		delete []ptr;
	else
		ptr=new ElemType[maxSize];
}

template<class ElemType>
SqList<ElemType>::~SqList()
{
	delete []ptr;
}

template<class ElemType>
void SqList<ElemType>::clear()
{
	count=0;
}

template<class ElemType>
int SqList<ElemType>::length()const
{
	return count;
}

template<class ElemType>
bool SqList<ElemType>::isEmpty()const
{
	return count==0;
}

template<class ElemType>
void SqList<ElemType>::Traverse(void(* visit)(ElemType & ))const
{
	for(int curPosition=0;curPosition<count;curPosition++)
		(* visit)(ptr[curPosition]);
}

template<class ElemType>
StatusCode SqList<ElemType>::setElem(int position,const ElemType &e)
{
	if(position<1||position>count)
		return RANGE_ERROR;
	else
	{
		ptr[position-1]=e;
		return SUCCESS;
	}
}

template<class ElemType>
StatusCode SqList<ElemType>::getElem(int position,ElemType &e)const
{
	if(position<1||position>count)
		return RANGE_ERROR;
	else
	{
		e=ptr[position-1];
		return SUCCESS;
	}
}

template<class ElemType>
StatusCode SqList<ElemType>::Delete(int position,ElemType &e)
{
	if(position<1||position>count)
		return RANGE_ERROR;
	e=ptr[position-1];
	for(int curPosition=position;curPosition<=count;curPosition++)
		ptr[curPosition-1]=ptr[curPosition];
	count-=1;
	return SUCCESS;
}

template<class ElemType>
StatusCode SqList<ElemType>::Insert(int position,const ElemType &e)
{
	//if((position+1)<2||(position+1)>Length())
	if(position<1||position>length()+1)
		return RANGE_ERROR;
	if(full())//注意判断是否线性表已经满了
		return OVER_FLOW;
	for(int curPosition=count;curPosition>=position;curPosition--)
		ptr[curPosition+1]=ptr[curPosition];
	ptr[curPosition]=e;
	count+=1;
	return SUCCESS;
}

template<class ElemType>
SqList<ElemType>::SqList(const SqList<ElemType> &copy)
{
	init(copy.maxSize);
	
	count=copy.count;
	for(curPosition=0;curPosition<count;curPosition++)
		ptr[curPosition]=copy.ptr[curPosition];
}

template<class ElemType>
SqList<ElemType>& SqList<ElemType>::operator = (const SqList<ElemType> &copy)
{
	if(&copy!=this)//注意判断copy是否等于本身
	{
		init(copy.maxSize);
		count=copy.count;
		for(curPosition=0;curPosition<count;curPosition++)
			ptr[curPosition]=copy.ptr[curPosition];
	
	}
	return *this;

}
#endif



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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值