C++实现单链表

阅读先知

链表是一种动态数据结构,他的特点是用一组任意的存储单元(可以是连续的,也可以是不连续的)存放数据元素。

链表中每一个元素成为“结点”,每一个结点都是由数据域和指针域组成的,每个结点中的指针域指向下一个结点。Head是“头指针”,表示链表的开始,用来指向第一个结点,而最后一个指针的指针域为NULL(空地址),表示链表的结束。

可以看出链表结构必须利用指针才能实现,即一个结点中必须包含一个指针变量,用来存放下一个结点的地址。

结点中只有一个next指针的链表称为单链表,这是最简单的链表结构。

具体实现

  1. 首先定义一个结构体,表示链表的节点

    typedef struct Node
    {
    ElemType data;
    struct Node *next;
    }LinkList;
  2. 建立单链表类

    class Mylist
    {
    private:
    LinkList* L;
    public:
    //初始化一个带头结点的单链表
    bool InitList()
    {
    L = new LinkList;
    if (L==NULL)
    {
    cout << "Not have enough memory!";
    return false;
    }
    L->next = NULL;
    return true;
    }
    bool CreateNode(int size)
    {
    int i = 0;
    ElemType e;
    LinkList* p =L;
    cout << ">>>>please input "<<size<<" nodes with space to split:";
    while(i<size)
    {
    LinkList* q = new LinkList;
    cin >> e;
    q->data = e;
    q->next = NULL;
    p->next = q;
    p = q;
    i++;
    }
    return true;
    }
    void DispList()
    {
    LinkList* p = L->next;
    while (p!=NULL)
    {
    cout << p->data<<' ';
    p = p->next;
    }
    cout << endl;
    }
    int ListLength()
    {
    int i = 0;
    LinkList* p = L->next;
    while (p!=NULL)
    {
    ++i;
    p = p->next;
    }
    return i;
    }
    bool ListEmpty()
    {
    return L->next == NULL;
    }
    bool GetElem(int site,ElemType &e)
    {
    int i =0;
    LinkList* p = L;
    while (i<site && p!=NULL)
    {
    i++;
    p = p->next;
    }
    if (p == NULL || site == 0)
    return false;
    else
    {
    e = p->data;
    return true;
    }
    }
    bool LocateElem(int &site,ElemType e)
    {
    int i = 1;
    LinkList* p = L->next;
    while (p!= NULL && p->data!=e)
    {
    i++;
    p = p->next;
    }
    if (p==NULL)
    return false;
    else
    site = i;
    return true;
    }
    //插入元素
    bool ListInsert(int site,ElemType e)
    {
    int i = 0;
    LinkList* p = L->next;
    while (i < site && p!=NULL)
    {
    i++;
    p = p->next;
    }
    if (p == NULL)
    return false;
    else
    {
    LinkList* q = new LinkList;
    q->data = e;
    q->next = NULL;
    p->next = q;
    return true;
    }
    }
    //删除元素
    bool ListDelete( int site, ElemType &e )
    {
    int i = 0;
    LinkList* p = L;
    while ( i<site-1 && p!=NULL )
    {
    i++;
    p = p->next;
    }
    if ( NULL == p )
    return false;
    else
    {
    LinkList* q = p->next;
    if ( NULL == q )
    return false;
    e = q->data;
    p->next = q->next;
    delete q;
    return true;
    }
    }
    // (带头一起)销毁链表
    void DestoryList()
    {
    LinkList *p, *q;
    p = L;
    while ( p!=NULL )
    {
    q = p->next;
    delete p;
    p = q;
    }
    }
    };

    主函数代码

    int main()
    {
    Mylist h;
    ElemType e;
    int temp=0;
    h.InitList();
    cout << ">>>>please input the length of linklist:";
    cin >> temp;
    h.CreateNode(temp);
    cout <<"show:";
    h.DispList();
    cout <<"the length of linklist is:"<<h.ListLength()<<endl;
    cout <<"is it empty?"<<h.ListEmpty()<<endl;
    cout << ">>>>which element do you want to find:";
    cin >> temp;
    h.GetElem(temp,e);
    cout <<"this element is "<<e<<endl;
    cout << ">>>>Which element index do you want to find:";
    cin >> temp;
    h.LocateElem(temp,temp);
    cout <<"this element index is "<<temp<<endl;
    return 0;
    }

    拓展应用

_题目描述:_判断链表是否带环,以及环的入口

  • 有一个单链表,其中可能有一个环,也就是某个节点的next指向的是链表中在它之前的任意一个节点,这样在链表尾部形成一个环。

主要思想:

  • 如果判断一个链表是否存在一个环?设定两个指针slow,fast,均从头指针开始,每次分别前进1步、2步。如果存在环,则两者相遇;如不存在环,fast遇到NULL退出。
  • 如果链表存在环,如何找到环的入口点?当fast与slow相遇时,slow肯定没有遍历完链表或者恰好遍历一遍。于是我们从链表头与相遇点分别设一个指针,每次各走一步,两个指针必定相遇,则相遇的第一个点为环入口点。

数学解析:

代码部分:

    bool findloopport(ElemType &e)
{
LinkList* fast = L;
LinkList* slow = L;
while (fast && fast->next)
{
slow = slow->next;
fast = fast->next->next;
if (slow == fast)
break;
}
if (fast == NULL || fast->next == NULL)
return false;
slow = L;
while (slow != fast)
{
slow = slow->next;
fast = fast->next;
}
e = slow->data;
return true;
}

温馨提示:代码可以根据个人习惯编写,本文还有待补缺的地方。。。。

singlelinklist的更多相关文章

  1. JAVA 链表操作:单链表和双链表

    主要讲述几点: 一.链表的简介 二.链表实现原理和必要性 三.单链表示例 四.双链表示例 一.链表的简介 链表是一种比较常用的数据结构,链表虽然保存比较复杂,但是在查询时候比较便捷,在多种计算机语言都 ...

  2. 剑指offer—第三章高质量代码(o(1)时间删除链表节点)

    题目:给定单向链表的头指针和一个节点指针,定义一个函数在O(1)时间删除该节点,链表节点与函数的定义如下:struct ListNode{int m_nValue;ListNode* m_pValue ...

  3. python数据结构链表之单向链表

    单向链表 单向链表也叫单链表,是链表中最简单的一种形式,它的每个节点包含两个域,一个信息域(元素域)和一个链接域.这个链接指向链表中的下一个节点,而最后一个节点的链接域则指向一个空值. 表元素域ele ...

  4. python 单向链表实现

    单链表的操作 is_empty() 链表是否为空 length() 链表长度 travel() 遍历整个链表 add(item) 链表头部添加元素 append(item) 链表尾部添加元素 inse ...

  5. 初始数据结构(python语言)

    数据结构 概念:数据结构是指相互之间存在着一种或多种关系的数据元素的集合和该集合中数据元素之间的关系组成 算法复杂度 时间复杂度 时间复杂度是同一问题可用不同算法解决,而一个算法的质量优劣将影响到算法 ...

  6. Python线性表——单链表

    1. 线性表简介 线性表是一种线性结构,它是由零个或多个数据元素构成的有限序列.线性表的特征是在一个序列中,除了头尾元素,每个元素都有且只有一个直接前驱,有且只有一个直接后继,而序列头元素没有直接前驱 ...

  7. 单链表的python实现

    首先说下线性表,线性表是一种最基本,最简单的数据结构,通俗点讲就是一维的存储数据的结构. 线性表分为顺序表和链接表: 顺序表示指的是用一组地址连续的存储单元依次存储线性表的数据元素,称为线性表的顺序存 ...

  8. python数据结构与算法第七天【链表】

    1.链表的定义 如图: 注意: (1)线性表包括顺序表和链表 (2)顺序表是将元素顺序地存放在一块连续的存储区里 (3)链表是将元素存放在通过链构造的存储快中 2. 单向链表的实现 #!/usr/bi ...

  9. 用python实现单向链表

    单向链表 单向链表也叫单链表,是链表中最简单的一种形式,它的每个节点包含两个域,一个信息域(元素域)和一个链接域.这个链接指向链表中的下一个节点,而最后一个节点的链接域则指向一个空值. 表元素域ele ...

随机推荐

  1. PAT B1081 检查密码

    题目描述: 本题要求你帮助某网站的用户注册模块写一个密码合法性检查的小功能.该网站要求用户设置的密码必须由不少于6个字符组成,并且只能有英文字母.数字和小数点 .,还必须既有字母也有数字. 输入格式: ...

  2. PAT B1024科学计数法

    科学计数法是科学家用来表示很大或很小的数字的一种方便的方法,其满足正则表达式 [+-][1-9].[0-9]+E[+-][0-9]+,即数字的整数部分只有 1 位,小数部分至少有 1 位,该数字及其指 ...

  3. Servlet 3.0以上版本使用@WebServlet注解配置映射

    以前的Servlet都是在web.xml中进行配置,导致web.xml中各个Servlet的映射非常杂乱无章,后期也很难维护 本篇文章将详细阐述如何使用Servlet 3.0的新特性使用@WebSer ...

  4. 微信小程序和公众号和H5之间相互跳转

    参考链接:https://www.imooc.com/article/22900 一.小程序和公众号 答案是:可以相互关联. 在微信公众号里可以添加小程序. 可关联已有的小程序或快速创建小程序.已关联 ...

  5. 《头号玩家》AI电影调研报告(五)

    4.VR自由行走跑步机 电影中,它可以让玩家朝任意方向无限奔跑并保持在平台最中央,还可以模拟上台阶和走斜坡的情况.而下面这件VR跑步装备,可以让你在游戏世界穿行自如. 奥地利创意公司Cyberith公 ...

  6. Vuecli版本调整

    1.当前版本号查看 1.Windows+R打开命令提示符2.输入cmd3.vue --version或者vue -V(大写V) 2.版本操作 安装指定版本 情况一:目前处于3.0及以上 版本查看和卸载 ...

  7. 安全开发运维必备,如何进行Nginx代理Web服务器性能优化与安全加固配置,看这篇指南就够了

    本章目录 1.引言 1.1 目的 1.2 目标范围 1.3 读者对象 2.参考说明 2.1 帮助参考 2.2 参数说明 3.3 模块说明 3.服务优化 3.1 系统内核 3.2 编译优化 3.3 性能 ...

  8. HashSet与TreeSet的区别

    HashSet元素唯一,无序,依靠hashcode(),toString()实现元素的唯一性 TreeSet元素唯一,有序,依靠bTo实现比较,即继承Comparable类并重写compareTo(O ...

  9. python学习-Day24

    目录 今日内容详细 主菜 : ATM+购物车作业 项目开发流程 需求分析 架构设计 分组开发 项目测试 交付上线 需求分析 提炼项目功能 项目大致技术栈 架构设计 编程历经过程 三层架构 将ATM分为 ...

  10. javascript生成一棵树

    问题描述 输入一串父子节点对的数组,利用其构造一颗树 输入 const arr = [ {id:1,parentid:null}, {id:2,parentid:1}, {id:3,parentid: ...