链表类的实现

定义链表的类的声明时采用模版机制,这样虽然繁琐一些,但为将来对链表的复用提供了很大的方便。同时在链表中增加头结点,统一了空表和非空表操作的实现,降低了程序结构的复杂性,减少了出错的概率。

头文件

#ifndef LINKLIST_H
#define LINKLIST_H
#include <cstddef>
#include <iostream>

/* 单链表的结点定义 */
template<class T>
struct LinkNode
{
    T data;
    LinkNode<T> *next;
    LinkNode(LinkNode<T> *ptr = NULL){next = ptr;}
    LinkNode(const T &item, LinkNode<T> *ptr = NULL)    
    //函数参数表中的形参允许有默认值,但是带默认值的参数需要放后面
    {
        next = ptr;
        data = item;
    }
};

/* 带头结点的单链表定义 */
template<class T>
class LinkList
{
public:
    //无参数的构造函数
    LinkList(){head = new LinkNode<T>;}
    //带参数的构造函数
    LinkList(const T &item){head = new LinkNode<T>(item);}
    //拷贝构造函数
    LinkList(LinkList<T> &List);
    //析构函数
    ~LinkList(){Clear();}
    //重载函数:赋值
    LinkList<T>& operator=(LinkList<T> &List);
    //链表清空
    void Clear();
    //获取链表长度
    int Length() const;
    //获取链表头结点
    LinkNode<T>* GetHead() const    {return head;}
    //查找数据的位置,返回第一个找到的满足该数值的结点指针
    LinkNode<T>* Find(T &item);
    //定位指定的位置,返回该位置上的结点指针
    LinkNode<T>* Locate(int pos);
    //在指定位置pos插入值为item的结点,失败返回false
    bool Insert(T &item, int pos);
    //删除指定位置pos上的结点,item就是该结点的值,失败返回false
    bool Remove(int pos, T &item);
    //获取指定位置pos的结点的值,失败返回false
    bool GetData(int pos, T &item);
    //设置指定位置pos的结点的值,失败返回false
    bool SetData(int pos, T &item);
    //判断链表是否为空
    bool IsEmpty() const;
    //打印链表
    void Print() const;
    //链表排序
    void Sort();
    //链表逆置
    void Reverse();
private:
    LinkNode<T> *head;
};

#endif

源文件

#include "LinkList.h"

//复制构造函数
template<class T>
LinkList<T>::LinkList(LinkList<T>& L)
{
    T value;
    LinkNode<T>* srcptr = L.GetHead();
    LinkNode<T>* destptr = head = new LinkNode<T>;
    while(srcptr->next != NULL){
        value = srcptr->next->data;
        destptr->next = new LinkNode<T>(value);
        srcptr = srcptr->next;
        destptr = destptr->next;
    }
    destptr->next = NULL;
}

//将链表置为空表
template<class T>
void LinkList<T>::Clear()
{
    LinkNode<T>* temp = NULL;
    while(head->next != NULL){
        temp = head->next;
        head->next = temp->next;
        delete temp;
    }
}



//计算待附加头结点的单链表长度
template<class T>
int LinkList<T>::Length() const
{
    int count = 0;
    LinkNode<T>* temp = head->next;
    while(temp != NULL){
        temp = temp->next;
        ++count;
    }
    return count;
}

//在表中搜索数据item的节点,搜索成功则返回该结点地址,否则返回NULL
template<class T> 
LinkNode<T>* LinkList<T>::Find(T &item)
{
    LinkNode<T>* temp = head->next;
    while(temp != NULL){
        if(temp->data == item)  break;
        else temp = temp->next;
    }
    return temp;
}

// 返回链表中第pos个元素的地址,如果pos<0或pos超出链表最大个数返回NULL
template<class T>
LinkNode<T>* LinkList<T>::Locate(int pos)
{
    int i = 0;
    LinkNode<T> *p = head;

    if (pos < 0)
        return NULL;

    while (NULL != p && i < pos)
    {
        p = p->next;
        i++;
    }
    
    return p;
}

//取出链表中第i个元素的值
template<class T>
bool LinkList<T>::GetData(int pos,T &item)
{
    if(pos<=0)  return false;
    LinkNode<T>* temp = Locate(pos);
    if(temp == NULL)    return false;
    else{
        item = temp->data;
        return true;
    }
} 

//给链表中第i个元素的赋值
template<class T>
bool LinkList<T>::SetData(int pos,T &item)
{
    if(pos<=0)  return false;
    LinkNode<T>* temp = Locate(pos);
    if(temp == NULL)    return false;
    else{
        temp->data = item;
        return true;
    }
}

//判断链表是否为空
template<class T>
bool LinkList<T>::IsEmpty() const
{
    return (head->next == NULL)?true:false;
}

template<class T>
bool LinkList<T>::Insert(T &item, int pos)
{
    LinkNode<T> *p = Locate(pos);
    if (NULL == p)
        return false;

    LinkNode<T> *node = new LinkNode<T>(item);
    if (NULL == node)
    {
        std::cerr << "分配内存失败!" << std::endl;
        exit(1);
    }
    node->next = p->next;
    p->next = node;
    return true;
}

template<class T>
bool LinkList<T>::Remove(int pos, T &item)
{
    LinkNode<T> *p = Locate(pos);
    if (NULL == p || NULL == p->next)
        return false;

    LinkNode<T> *del = p->next;
    p->next = del->next;
    item = del->data;
    delete del;
    return true;
}


template<class T>
void LinkList<T>::Print() const
{
    int count = 0;
    LinkNode<T> *p = head;
    while (NULL != p->next)
    {
        p = p->next;
        std::cout << p->data <<std::endl;
    }
}


template<class T>
void LinkList<T>::Reverse()
{
    LinkNode<T> *pre = head->next;
    LinkNode<T> *curr = pre->next;
    LinkNode<T> *next = NULL;

    head->next->next = NULL;
    while (curr)
    {
        next = curr->next;
        curr->next = pre;
        pre = curr;
        curr = next;
    }
    head->next = pre;
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,456评论 5 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,370评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,337评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,583评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,596评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,572评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,936评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,595评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,850评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,601评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,685评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,371评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,951评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,934评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,167评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,636评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,411评论 2 342

推荐阅读更多精彩内容

  • B树的定义 一棵m阶的B树满足下列条件: 树中每个结点至多有m个孩子。 除根结点和叶子结点外,其它每个结点至少有m...
    文档随手记阅读 13,149评论 0 25
  • 本文内容取自于小甲鱼的数据结构与算法。http://www.jianshu.com/p/230e6fde9c75 ...
    阿阿阿阿毛阅读 2,867评论 0 7
  • 作为一个资深的新手程序员😂,链表这些既基础又深奥的东西是日常工作中并不常见,但是却非常重要,所以就总结一下链表的简...
    Clark_new阅读 4,234评论 4 12
  • 大学的时候不好好学习,老师在讲台上讲课,自己在以为老师看不到的座位看小说,现在用到了老师讲的知识,只能自己看书查资...
    和珏猫阅读 1,434评论 1 3
  • 还记得饶平二中下操场的大台阶旁那几棵杨桃树吗?树上开满了杨桃花。二十几年前,我摘下了它,夹在我的书里也夹在了记忆里...
    敏Yang阅读 665评论 9 3