顺序表的模板实现

  • 头文件
#pragma once

template <typename T>

class SeqList
{
public:
    SeqList(int capcity);
    ~SeqList();
    int getLength();

    int getCapacity();

    int insert(T &t, int pos);

    int get(int pos,T& t);

    int Delete(int pos, T& t);

private:
    int length;
    int capacity;
    T  *pArray;
};

  • 实现文件
#include "SeqList.h"

template <typename T>
SeqList<T>::SeqList(int capcity)
{
    pArray = new T[capcity];
    this->capacity = capcity;
    this->length = 0;
}

template <typename T>
SeqList<T>::~SeqList()
{
    delete[]pArray;
    pArray = NULL;
    length = 0;
    capacity = 0;
}

template <typename T>
int SeqList<T>::getLength()
{
    return length;
}

template <typename T>
int SeqList<T>::getCapacity()
{
    return capacity;
}

template <typename T>
int SeqList<T>::insert(T &t, int pos)
{
    int  i = 0;
    if ( pos < 0)
    {
        return -1;
    }

    for (i = length; i> pos; i--)
    {
        pArray[i] = pArray[i - 1];
    }

    pArray[i] = t;

    length++;

    return 0;
}

template <typename T>
int SeqList<T>::get(int pos, T& t)
{
    if ( pos < 0)
    {
        return -1;
    }

    t = pArray[pos];

    return 0;
}

template <typename T>
int SeqList<T>::Delete(int pos, T& t)
{
    int  i = 0;

    if ( pos < 0)
    {
        return -1;
    }

    t = pArray[pos];

    for (i = pos + 1; i <length;i++)
    {
        pArray[i - 1] = pArray[i];
    }
    length--;

    return 0;
}
  • 测试文件
#include <iostream>
#include "SeqList.cpp"
using namespace std;

typedef struct _teacher
{
    char name[64];
    int age;
}Teacher;

void main_play(void)
{

    Teacher t1, t2, t3,tmp;
    t1.age = 31;
    t2.age = 32;
    t3.age = 33;

    SeqList<Teacher> list(10);

    list.insert(t1, 0);
    list.insert(t2, 0);
    list.insert(t3, 0);

    for (int i = 0; i < list.getLength();i++)
    {
        list.get(i, tmp);
        cout << tmp.age << " ";
    }

    while (list.getLength()>0)
    {
        list.Delete(0,tmp);
        cout << tmp.age << " ";
    }

    return;
}

int main(void)
{

    main_play();

    cout << "Hello!" << endl;
    system("pause");
    return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值