时间:2021-05-20
本文实例讲述了C++语言实现线性表之数组。分享给大家供大家参考。具体分析如下:
感觉用C++中的构造函数、析构函数等类的特点来描述一些数据结构更加易读,更加合理,便捷。但有一个问题,编译器不支持模板的分离编译,很不舒服
#include <iostream>using namespace std;template<class T>class CArray{public: CArray(const int &iMax); CArray(); ~CArray(); void Create(const int &iMax); void Destroy(); void Print(); bool IsEmpty(); bool IsFull(); void Append(const T &data); int GetLength(); int GetMax(); bool Delete(const int &pos); bool Insert(const int &pos,const T &data); void operator+=(const T &data);private: T *m_pArray; int m_len; int m_max; void Reset();};template<class T>CArray<T>::CArray(const int &iMax){ Create(iMax);}template<class T>CArray<T>::~CArray(){ Destroy();}template<class T>void CArray<T>::Create(const int &iMax){ m_pArray = new T[iMax]; m_max = iMax; m_len = 0; memset(m_pArray,0,sizeof(m_pArray));}template<class T>void CArray<T>::Destroy(){ delete [] m_pArray;}template<class T>void CArray<T>::Print(){ if(IsEmpty()) { cout<<"没有数据!"<<endl; } else { for(int ix =0 ; ix < m_len ; ++ix) { cout<<m_pArray[ix]<<","; } cout<<endl; }}template<class T>bool CArray<T>::IsEmpty(){ if(0 == m_len) { return true; } else { return false; }}template<class T>bool CArray<T>::IsFull(){ if(m_len == m_max) { Reset(); return false; } else { return false; }}template<class T>void CArray<T>::Append(const T &data){ if(!IsFull()) { ++m_len; m_pArray[m_len - 1] = data; }}template<class T>int CArray<T>::GetLength(){ return m_len;}template<class T>bool CArray<T>::Delete(const int &pos){ if(pos > m_len || pos <= 0) { cout<<"位置不合法"<<endl; return false; } for(int ix = pos - 1 ; ix < m_len - 1 ; ++ ix) { m_pArray[ix] = m_pArray[ix + 1]; } --m_len; return true;}template<class T>void CArray<T>::operator+=(const T &data){ this->Append(data);}template<class T>bool CArray<T>::Insert(const int &pos,const T &data){ if(IsFull()) { return false; } else { for(int ix = m_len - 1 ; ix >= pos - 1 ; -- ix) { m_pArray[ix + 1] = m_pArray[ix]; } m_pArray[pos - 1] = data; ++m_len; return true; }}template<class T>CArray<T>::CArray(){ Create(5);}template<class T>void CArray<T>::Reset(){ T *pT = new T[m_max * 2]; memset(pT,0,sizeof(pT)); for(int ix = 0 ; ix < m_len ; ++ ix) { pT[ix] = m_pArray[ix]; } delete [] m_pArray; m_pArray = pT; m_max = m_max * 2;}template<class T>int CArray<T>::GetMax(){ return m_max;}希望本文所述对大家的C++程序设计有所帮助。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
C++数据结构线性表-数组实现线性表的数组实现,实现几个核心的功能,语言是C++,如果有更好的想法和意见,欢迎留言~~~/*Author:Moyiii*线性表的
之前在学习c语言的时候用c语言实现了动态线性表。现在再使用c++实现一下动态线性表。相关数据结构方面就不多说了。在之前的博客里也有。下面就直接来实现吧。这里使用
本文实例讲述了C++语言实现线性表之链表实现方法。分享给大家供大家参考。具体分析如下:插入、删除结点的代码有点多,但这样提高了代码的可读性,且不增加时间复杂度,
本文实例讲述了C语言实现顺序表(线性表)的方法。分享给大家供大家参考,具体如下:一:顺序表代码实现?123456789101112131415161718192
C语言实现动态顺序表的实现代码顺序表是在计算机内存中以数组的形式保存的线性表,是指用一组地址连续的存储单元依次存储数据元素的线性结构。线性表采用顺序存储的方式存