C++模板类链表实现

模板类链表
编写过程参考了:
http://blog.youkuaiyun.com/qinmusiyan/article/details/39830195
头结点不为空
节点计数从1开始
由于是模板类,声明和定义都放在头文件里
编写注意事项:
每个节点增加时有且只能定义一个分配一个动态内存(new)
时时判断头结点是否为空,如果为NULL,插入时必须在header上进行

#ifndef Linklist_h
#define Linklist_h
#include <iostream>
template <typename T>
struct node
{
    T date;
    node* pNext;
};

template <typename T>
class Linklist
{
public:
    Linklist();
    Linklist(const Linklist<T> &list);
    Linklist<T>& operator= (const Linklist<T> &rhs);
    ~Linklist();
public:
    void headAdd(const T& date); //在头结点插入
    void rearAdd(const T& date); //在尾节点插入
    int size() const; //返回链表长度
    bool isEmpty() const; //判断是否为空
    void print() const; //遍历链表
    T getNElement(int n) const; //返回链表第n个节点值
    void insertNElement(int n,const T& data);//将元素插入在链表的第pos位置上;
    void deleteNElement(int n = 1); //删除第n个节点
    void modifyElement(int n, const T& date); //修改n位置的元素值为x;
    int find(const T& date); //查找x第一次出现的位置,若没有,返回-1;
    void sort(); //对链表元素进行升序排序;  
    void destroy();//销毁链表,将链表成为空链表;

private:
    node<T>* header;
    int length;

};

template <typename T>
Linklist<T>::Linklist() :header(NULL), length(0) {};

template <typename T>
Linklist<T>::Linklist(const Linklist<T> &list) : header(NULL), length(0)
{
    int i = 1;
    while (i <= list.size())
    {
        rearAdd(list.getNElement(i));
        i++;
    }
}

template <typename T>
Linklist<T>& Linklist<T>::operator= (const Linklist<T> &rhs)
{
    if (this == &rhs)
    {
        return *this;
    }
    destroy();
    for (int i = 1; i <= rhs.size(); ++i)
    {
        rearAdd(rhs.getNElement(i));
    }
    return *this;
}

template <typename T>
Linklist<T>::~Linklist()
{
    destroy();
}

template <typename T>
void Linklist<T>::headAdd(const T& date)
{
    node<T> *pnode = new node<T>;
    pnode->date = date;
    pnode->pNext = NULL;
    if (header == NULL)
    {
        header = pnode;
    }
    else
    {
        pnode->pNext = header;
        header = pnode;
    }
    length++;
}

template <typename T>
void Linklist<T>::rearAdd(const T& date)
{
    node<T> *pnode = new node<T>;
    pnode->date = date;
    pnode->pNext = NULL;
    if (header == NULL)
    {
        header = pnode;
    }
    else
    {
        node<T>* rear = header;
        while (rear->pNext != NULL)
        {
            rear = rear->pNext;
        }
        rear->pNext = pnode;        
    }
    length++;
}

template <typename T>
int Linklist<T>::size() const
{
    return length;
}

template <typename T>
bool Linklist<T>::isEmpty() const
{
    return header == NULL;
}

template <typename T>
void Linklist<T>::print() const
{
    node<T> *ptemp = header;
    int count = 0;
    while (ptemp != NULL)
    {
        std::cout << ptemp->date << "\t";
        ptemp = ptemp->pNext;
        count++;
        if (count % 5 == 0)
        {
            std::cout << std::endl;
        }
    }
    std::cout << std::endl;
}

template <typename T>
T Linklist<T>::getNElement(int n) const
{
    if (n < 1 || n > length)
    {
        throw "获得元素位置非法!";
    }
    else
    {
        int i = 1;
        node<T> *ptemp = header;
        while (i++ < n)
        {
            ptemp = ptemp->pNext;
        }
        return ptemp->date;
    }
}

template <typename T>
void Linklist<T>::insertNElement(int n, const T& date)
{
    if (n < 1 || n > length)
    {
        std::cout << "插入元素位置非法!" << std::endl;
    }
    else
    {
        if (n == 1)
        {
            node<T> *ptemp = new node<T>;
            ptemp->date = date;
            ptemp->pNext = header;
            header = ptemp;
        }
        else
        {
            int i = 1;
            node<T> *ptemp = header;
            while (++i < n)
            {
                ptemp = ptemp->pNext;
            }
            node<T> *pinsert = new node<T>;
            pinsert->date = date;
            pinsert->pNext = ptemp->pNext;
            ptemp->pNext = pinsert;
        }
        length++;
    }
    return;
}

template <typename T>
void Linklist<T>::deleteNElement(int n = 1)
{
    if (n < 1 || n > length)
    {
        std::cout << "删除元素位置非法!" << std::endl;
    }
    else
    {
        node<T> *deleteElement;
        if (n == 1)
        {
            deleteElement = header;
            header = header->pNext;
        }
        else
        {
            int i = 1;
            node<T> *ptemp = header;
            while (++i < n)
            {
                ptemp = ptemp->pNext;
            }
            deleteElement = ptemp->pNext;
            ptemp->pNext = deleteElement->pNext;

        }
        delete deleteElement;
        length--;
    }
    return;
}

template <typename T>
void Linklist<T>::modifyElement(int n, const T& date)
{
    if (n < 1 || n > length)
    {
        std::cout << "修改元素位置非法!" << std::endl;
    }
    else
    {
        if (n == 1)
        {
            header->date = date;
        }
        else
        {
            node<T> *ptemp = header;
            int i = 1;
            while (i++ < n)
            {
                ptemp = ptemp->pNext;
            }
            ptemp->date = date;
        }
    }
    return;
}

template <typename T>
int Linklist<T>::find(const T& date)
{
    int i = 1;
    int re = -1;
    node<T> *ptemp = headr;
    while (!ptemp)
    {
        if (ptemp->date == date)
        {
            re = i;
            break;
        }
        i++;
        ptemp = ptemp->pNext;
    }
    return re;
}

template <typename T>
void Linklist<T>::sort()
{
    if (length > 1)
    {
        for (int i = length; i > 0; --i)
        {
            for (int j = 1; j < i; j++)
            {
                T lift = getNElement(j);
                T right = getNElement(j + 1);
                if (lift > right)
                {
                    modifyElement(j, right);
                    modifyElement(j + 1, lift);
                }
            }
        }
    }
    return;
}

template <typename T>
void Linklist<T>::destroy()
{
    while (header != NULL)
    {
        node<T> *ptemp = header;
        header = header->pNext;
        delete ptemp;
    }
    length = 0;
}

#endif

测试运行部分:

#include "Linklist.h"
#include <iostream>
int main()
{
    Linklist<int> link;
    for (int i = 10; i > 0; --i)
    {
        link.rearAdd(i);
    }
    link.print();
    std::cout << link.size() << std::endl;
    Linklist<int> link1(link);
    link1 = link1;
    link1.print();
    link1.deleteNElement(100);
    link1.modifyElement(5, 100);
    link1.insertNElement(3, 50);
    std::cout << link1.size() << std::endl;
    link1.print();

    link1.sort();
    link1.print();
    link1.destroy();
    std::cout << link1.size() << std::endl;
    system("pause");
    return 0;
}
面向对象程序设计课程作业 1. 请创建一个数据类型为T的链表模板List,实现以下成员函数: 1) 默认构造函数List(),将该链表初始化为一个空链表(10分) 2) 拷贝构造函数List(const List& list),根据一个给定的链表构造当前链表(10分) 3) 析构函数~List(),释放链表中的所有节点(10分) 4) Push_back(T e)函数,往链表最末尾插入一个元素为e的节点(10分) 5) operator<<()友元函数,将链表的所有元素按顺序输出(10分) 6) operator=()函数,实现两个链表的赋值操作(10分) 7) operator+()函数,实现两个链表的连接,A=B+C(10分) 2. 请编写main函数,测试该类模板的正确性: 1) 用List模板定义一个List类型的模板类对象int_listB,从键盘读入m个整数,调用Push_back函数将这m个整数依次插入到该链表中;(4分) 2) 用List模板定义一个List类型的模板类对象int_listC,从键盘读入n个整数,调用Push_back函数将这n个整数依次插入到该链表中;(4分) 3) 用List模板定义一个List类型的模板类对象int_listA,调用List的成员函数实现A = B + C;(4分) 4) 用cout直接输出int_listA的所有元素(3分) 5) 用List模板定义List类型的模板类对象double_listA, double_listB, double_listC,重复上述操作。(15分) 3. 输入输出样例: 1) 输入样例 4 12 23 34 45 3 56 67 78 3 1.2 2.3 3.4 4 4.5 5.6 6.7 7.8 2) 输出样例 12 23 34 45 56 67 78 1.2 2.3 3.4 4.5 5.6 6.7 7.8
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值