线性表

#pragma once
#include <iostream>
#include <Windows.h>
using namespace std;

template<class DataType>

class CMyArray
{
public:
	CMyArray(int iSize);
	virtual ~CMyArray(void);

	BOOL Insert(DataType Item,int iIndex);
	BOOL Remove(int iIndex);
	DataType& operator[](int iIndex);
	DataType* GetPointer();
	int Size();
	int CurSize();
	BOOL ReSize(int iSize);
	void Show();
private:
	DataType* m_pArray;
	int m_iSize;
	int m_iCurSize;
};

template<class DataType>
CMyArray<DataType>::CMyArray(int iSize)
{
	m_pArray=new DataType[iSize];
	for (int index=0;index<iSize;index++)
	{
		m_pArray[index]=0;
	}
	m_iSize=iSize;
	m_iCurSize=0;
}

template<class DataType>
CMyArray<DataType>::~CMyArray(void)
{
	if (NULL!=m_pArray)
	{
		delete[] m_pArray;
		m_pArray=NULL;
	}
}

template<class DataType>
BOOL CMyArray<DataType>::Insert(DataType Item,int iIndex)
{	
	if (iIndex<0 || iIndex>=m_iSize)
	{
		return FALSE;
	}
	for (int index=m_iSize-1;index>iIndex;index--)
	{
		m_pArray[index]=m_pArray[index-1];
	}
	m_pArray[iIndex]=Item;
	m_iCurSize++;
	return TRUE;
}

template<class DataType>
BOOL CMyArray<DataType>::Remove(int iIndex)
{
	if (iIndex<0 || iIndex>=m_iSize)
	{
		return FALSE;
	}
	for (int index=iIndex+1;index<m_iSize;index++)
	{
		m_pArray[index-1]=m_pArray[index];
	}
	m_iCurSize--;
	return TRUE;
}

template<class DataType>
int CMyArray<DataType>::Size()
{
	return m_iSize;
}

template<class DataType>
int CMyArray<DataType>::CurSize()
{
	return m_iCurSize;
}

template<class DataType>
BOOL CMyArray<DataType>::ReSize(int iSize)
{
	DataType* mNewArray=new DataType[iSize];
	if (NULL==mNewArray)
	{
		return FALSE;
	}
	int iMin=0;
	if (iSize<m_iSize)
	{
		iMin=iSize;
	}
	else
		iMin=m_iSize;
	for (int index=0;index<iMin;index++)
	{
		mNewArray[index]=m_pArray[index];
	}
	m_iSize=iSize;
	m_iCurSize=iSize;
	if (NULL!=m_pArray)
	{
		delete[] m_pArray;
		m_pArray=NULL;
	}
	m_pArray=mNewArray;

	return TRUE;
}

template<class DataType>
DataType& CMyArray<DataType>::operator [](int iIndex)
{
	if (iIndex<0 || iIndex>=m_iSize)
	{
		return NULL;
	}
	return m_pArray[iIndex];
}

template<class DataType>
DataType* CMyArray<DataType>::GetPointer()
{
	return m_pArray;
}

template<class DataType>
void CMyArray<DataType>::Show()
{
	cout<<"Total Size="<<m_iSize<<endl;
	cout<<"Curent Size="<<m_iCurSize<<endl;
	for (int index=0;index<m_iSize;index++)
	{
		cout<<m_pArray[index]<<endl;
	}
}

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值