iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > 其他教程 >C++代码实现双向链表
  • 687
分享到

C++代码实现双向链表

2024-04-02 19:04:59 687人浏览 薄情痞子
摘要

本文实例为大家分享了c++实现双向链表的具体代码,供大家参考,具体内容如下 双向链表:两个指针域,一个指向前结点,一个指向后结点 list.h #pragma once #defin

本文实例为大家分享了c++实现双向链表的具体代码,供大家参考,具体内容如下

双向链表:两个指针域,一个指向前结点,一个指向后结点

list.h

#pragma once
#define OK         1
#define ERROR     0
#define TRUE     1
#define FALSE     0

typedef int Status;
typedef int ElemType;

typedef struct Dnode
{
    struct DNode *prior;        //前结点指针域
    ElemType data;                //数据域
    struct DNode *next;            //后结点指针域
}DNode, *DLinkList;                //结点和指向结点的指针

bool InitDLinkList(DLinkList &L);                        //双链表初始化
Status CreatDLinkList(DLinkList &L);                    //尾插法创建链表,包含初始化功能
bool InsertNextDNode(DNode *p, DNode *s);                //结点s插入在结点p之后
Status DeleteNextDNode(DNode *p, ElemType &e);            //删除结点p的后继节点                
void ListTraverse(const DLinkList L);                    //双链表的遍历
Status ListInsert(DLinkList &L, int i, ElemType e);        //指定位置插入元素
Status ListDelete(DLinkList &L, int i, ElemType &e);    //指定位置删除元素
DNode* GetElem(DLinkList L, int i);                        //查找链表指定位置节点,返回的是结点
void DestoryList(DLinkList &L);                            //销毁双链表,需要释放头结点

oper_func.cpp

#include <iOStream>
#include"list.h"

bool InitDLinkList(DLinkList &L)
{
    //构建空的双链表,作为双链表的头结点,数据域为空
    L = new DNode;
    if (L == NULL)                //内存分配失败
        return FALSE;
    L->prior = NULL;            //头结点的前驱指针始终指向NULL    
    L->next = NULL;                //暂时指向NULL
    return TRUE;
}

Status CreatDLinkList(DLinkList &L)
{
    //利用InsertNextDNode函数来创建

    using std::cin;
    using std::cout;
    using std::endl;
    if (InitDLinkList(L))
    {
        DNode *s,*r = L;                //s为新建的新结点,用来存储数据,而r为尾指针,始终指向尾部节点
        int num;
        cout << "输入你需要创建的双链表的个数:";
        cin >> num;
        for (int i = 1; i <= num; i++)
        {
            s = new DNode;                //创建的新结点
            cout << "输入第" << i << "个元素:";
            cin >> s->data;                //输入数据
            s->next = NULL;
            InsertNextDNode(r,s);        //结点s插在尾部节点之后
            r = s;                        //尾指针指向新的尾结点
        }
        return OK;
    }
    else
    {
        cout << "内存不够,单链表创建失败!" << endl;
        return ERROR;
    }
}

//结点s插入在结点p之后
bool InsertNextDNode(DNode *p, DNode *s)
{
    if (p == NULL || s == NULL)
        return FALSE;            //非法参数
    s->next = p->next;
    if (p->next != NULL)        //如果p不是最后一个结点
    {
        p->next->prior = s;
    }
    s->prior = p;
    p->next = s;
    return TRUE;
}

Status DeleteNextDNode(DNode *p, ElemType &e)
{
    if(p == NULL)
        return FALSE;            //非法参数
    DNode *q = p->next;            //找到p节点的后继节点
    if (q == NULL)                //节点p没有后继节点
    {
        return ERROR;
    }
    else
    {
        //有后继节点,但是p的后继节点为空
        p->next = q->next;
        e = q->data;
        if (q->next != NULL)
        {
            q->next->prior = p;
        }
        delete q;
        return OK;
    }
}

void ListTraverse(const DLinkList L)
{
    using std::cout;
    using std::endl;
    int i = 1;
    DNode *p = L->next;                    //指向第一个元素
    if (p == NULL)
    {
        cout << "双链表为空,无法输出元素!" << endl;
        return;
    }
    while (p)
    {
        cout << "第" << i++ << "个元素为:" << p->data << endl;
        p = p->next;
    }
}

Status ListDelete(DLinkList &L, int i, ElemType &e)
{
    if (i < 1)                 //位置不合理
        return ERROR;
    //寻找第i-1个结点
    DNode *p = GetElem(L, i - 1);
    //删除i-1结点的后面结点
    return DeleteNextDNode(p,e);
}

DNode* GetElem(DLinkList L, int i)
{
    DNode *p = L;
    int j = 0;                //表示p指向的当前结点的位置,此时为头结点
    while (p != NULL && j < i)
    {
        p = p->next;        //指向下一个结点
        j++;
    }
    return p;
}

void DestoryList(DLinkList &L)
{
    using std::cout;
    using std::endl;
    ElemType temp;
    int i = 1;
    while (L->next != NULL)
    {
        DeleteNextDNode(L,temp);
        cout << "第" << i++ << "个删除的元素为:" << temp << endl;
    }
    cout << "双链表全部数据销毁成功!" << endl;
    delete L;
    cout << "头结点销毁,整个双链表销毁成功!" << endl;
    L = NULL;                //头指针指向NULL
}

Status ListInsert(DLinkList &L, int i, ElemType e)
{
    if (i < 1)
        return FALSE;
    //寻找第i-1个结点
    DNode *p = GetElem(L, i - 1);
    //直接在i-1结点的后面插入元素即可
    DNode *s = new DNode;        //新建节点
    s->data = e;
    s->next = NULL;
    s->prior = NULL;
    return InsertNextDNode(p,s);
}

main.cpp



#include <iostream>
#include"list.h"

void showMenu()
{
    using std::cout;
    using std::cin;
    using std::endl;
    cout << "*********************************************************" << endl;
    cout << "*** 1.指定位置插入元素            2.删除指定位置元素 ***" << endl;
    cout << "*** 3.遍历单链表            0.销毁双链表并退出 ***" << endl;
    cout << "*********************************************************" << endl;
}

int main()
{
    using std::cout;
    using std::cin;
    using std::endl;
    int select = 0, flag = -1;            //输入的选择

    DLinkList L;                //L表示头指针,始终指向表头

    if (CreatDLinkList(L))        //尾插法创建单链表
    {
        cout << "双链表创建成功!" << endl;
    }
    else
        cout << "双链表创建失败!" << endl;

    while (true)
    {
        showMenu();
        cout << "输入你的选择:";
        cin >> select;
        switch (select)
        {
        case 1: {        //指定位置插入元素
            int position = 0, elem = 0;
            cout << "输入插入的位置和元素:";
            cin >> position >> elem;
            if (ListInsert(L, position, elem))
                cout << "指定位置插入元素成功!" << endl;
            else
                cout << "内存分配失败或者插入位置越界,插入失败!" << endl;
        }
                break;
        case 2: {        //删除指定位置节点
            int position = 0, elem = 0;
            cout << "输入指定位置:";
            cin >> position;
            if (ListDelete(L, position, elem))
            {
                cout << "删除指定位置元素成功!元素为:" << elem << endl;
            }
            else
            {
                cout << "单链表为空或者删除位置不合理!" << endl;
            }
        }
                break;
        case 3: {
            ListTraverse(L);
        }
                break;
        case 0: {
            DestoryList(L);
            system("pause");
            return 0;
        }
        break;
        }
    }
    return 0;
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程网。

--结束END--

本文标题: C++代码实现双向链表

本文链接: https://www.lsjlt.com/news/149858.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • C++代码实现双向链表
    本文实例为大家分享了C++实现双向链表的具体代码,供大家参考,具体内容如下 双向链表:两个指针域,一个指向前结点,一个指向后结点 list.h #pragma once #defin...
    99+
    2024-04-02
  • C++实现双向链表代码分析
    目录前言:一、双向链表优缺点二、C++实现分析(1)节点类(2)链表类分析(3)链表类构造函数(4)isEmpty()判断是否为空(5)size()获取链表长度(6)getNode(...
    99+
    2024-04-02
  • java代码实现双向链表
    本文实例为大家分享了双向链表java实现代码,供大家参考,具体内容如下 一、双向链表简介 1、单链表的缺陷 单链表只能从头结点开始访问链表中的数据元素,如果需要逆序访问单链表中的数据...
    99+
    2024-04-02
  • 如何使用C++代码实现双向链表
    这篇文章主要介绍“如何使用C++代码实现双向链表”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“如何使用C++代码实现双向链表”文章能帮助大家解决问题。双向链表:两个指针域,一个指向前结点,一个指向后...
    99+
    2023-06-30
  • 怎么用java代码实现双向链表
    这篇文章主要介绍“怎么用java代码实现双向链表”,在日常操作中,相信很多人在怎么用java代码实现双向链表问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么用java代码实现双向链表”的疑惑有所帮助!接下来...
    99+
    2023-06-30
  • java双向循环链表的实现代码
    例1:复制代码 代码如下:package com.xlst.util; import java.util.HashMap;import java.util.Map;import ja...
    99+
    2022-11-15
    java 双向循环链表
  • C++怎么实现双向链表
    这篇“C++怎么实现双向链表”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“C++怎么实现双向链表”文章吧。前言:前面文章分析...
    99+
    2023-06-29
  • C++实现通用双向链表
    使用C++完成双向通用链表双向链表不用多说,通用链表因为数据结构不确定的,使用一个VOID指针指向数据,什么数据都可以挂上去,这样来封装链表,可以作为基础类也可以单独使用,这里只是为了练习C++封装的语法,实现了简单的增加和删除链表由于实际...
    99+
    2023-06-04
  • C语言如何实现双向链表和双向循环链表
    本文小编为大家详细介绍“C语言如何实现双向链表和双向循环链表”,内容详细,步骤清晰,细节处理妥当,希望这篇“C语言如何实现双向链表和双向循环链表”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。双向链表和双向循环链表...
    99+
    2023-06-16
  • Python代码实现双链表
    本文实例为大家分享了Python代码实现双链表的具体代码,供大家参考,具体内容如下 双链表的每个节点有两个指针: 一个指向后一个节点,另一个指向前一个节点 class Node(ob...
    99+
    2024-04-02
  • Python实现双向链表
    之前写的单向链表和环形链表都只是单向的,只能单向遍历,不能根据后面的节点获取前面的节点,除非进行反转操作。 双向链表每个节点都有两个指针,这两个指针分别指向前后两个节点,这样就可以从...
    99+
    2024-04-02
  • Java实现双向链表
    本文实例为大家分享了Java实现双向链表的具体代码,供大家参考,具体内容如下 1、双向链表 1.1 双向链表的每个节点组成包含节点数据,上一个节点(pre),下一个节点(next) ...
    99+
    2024-04-02
  • C语言如何实现双向链表
    本篇内容介绍了“C语言如何实现双向链表”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!双向链表的基本操作    ...
    99+
    2023-06-16
  • C++双向循环链表类模版实例代码分析
    本文小编为大家详细介绍“C++双向循环链表类模版实例代码分析”,内容详细,步骤清晰,细节处理妥当,希望这篇“C++双向循环链表类模版实例代码分析”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。1.插入某个节点流程如...
    99+
    2023-06-29
  • Java实现双链表的示例代码
    目录一、双向链表是什么二、具体方法实现定义结点下标访问异常获取链表长度打印链表清空链表头插法尾插法指定位置插入查找元素删除第一次出现的关键字删除所有值为key的节点三、完整代码一、双...
    99+
    2024-04-02
  • Java如何实现双向链表
    本篇内容介绍了“Java如何实现双向链表”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!1、双向链表1 双向链表的每个节点组成包含节点数据,上...
    99+
    2023-06-30
  • java双向链表怎么实现
    Java中的双向链表可以通过定义一个Node类来实现,该类包含一个值和两个指针,分别指向前一个节点和后一个节点。具体实现如下: pu...
    99+
    2023-10-22
    java
  • Python 实现双向链表(图解)
    双向链表 双向链表也叫双链表,是链表的一种,它的每个数据结点中都有两个指针,分别指向直接后继和直接前驱。所以,从双向链表中的任意一个结点开始,都可以很方便地访问它的前驱结点和后继结点。 双向链表基本方法实现(Python) 1...
    99+
    2023-01-31
    双向 链表 Python
  • python双向链表怎么实现
    这篇文章主要介绍“python双向链表怎么实现”,在日常操作中,相信很多人在python双向链表怎么实现问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”python双向链表怎么实现”的疑惑有所帮助!接下来,请跟...
    99+
    2023-06-30
  • 怎么用Python代码实现双链表
    本文小编为大家详细介绍“怎么用Python代码实现双链表”,内容详细,步骤清晰,细节处理妥当,希望这篇“怎么用Python代码实现双链表”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。双链表的每个节点有两个指针: ...
    99+
    2023-06-30
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作