C++数据结构之双向链表

 更新时间:2022年05月26日 16:36:48   作者:W...Z  
这篇文章主要为大家详细介绍了C++数据结构之双向链表,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了C++数据结构之双向链表的具体代码,供大家参考,具体内容如下

#include <iostream>
using std::cout;
using std::endl;
struct Node
{
    int data;
    struct Node * next;
    struct Node * pre;
};

一、创建双向链表

Node * createList()
{
    Node * head = new Node;
    if (NULL == head)
        exit(-1);
    head->next = head;
    head->pre = head;
    return head;
}

二、插入元素(头插法)

让新来的节点先有所指

void insertList(Node * head,int n)
{
    Node * cur = new Node;
    if (NULL == cur)
        exit(-1);
    cur->next = head->next;
    cur->pre = head;
    head->next = cur;
    cur->next->pre = cur;
    
    cur->data = n;
}

三、链表长度

int lenList(Node * head)
{
    int i = 0;
    Node * t = head->next;
    while (t != head)
    {
        i++;
        t = t->next;
    }
    return i;
}

四、查找遍历

Node * findList(Node * head,int fn)
{
    Node * forward = head->next;
    Node * back = head->pre;
    while (forward != back->next)
    {
        if (forward->data == fn)
            return forward;
        if (back->data == fn)
            return back;
        if (forward == back)
            break;
        forward = forward->next;
        back = back->pre;
    }
    return NULL;
}

五、删除其中元素

void deleteList(Node * pFind)
{
    pFind->pre->next = pFind->next;
    pFind->next->pre = pFind->pre;
    delete pFind;
}

六、排序

(类似于先删除 再插入)

void sortDlist(Node * head)
{
    int len = lenList(head);
    Node *prep = NULL;
    Node *p = NULL;
    Node *q = NULL;
    Node *t = NULL;
    for (int i = 0;i < len - 1;i++)
    {
        p = head->next;
        q = p->next;
        for (int j = 0;j < len - 1 - i;j++)
        {
            if ((p->data)<(q->data))
            {
                p->pre->next = q;
                q->pre = p->pre;

                p->next = q->next;
                p->pre = q;

                q->next = p;
                p->next->pre = p;

                t = p;
                p = q;
                q = t;
            }
            p = p->next;
            q = q->next;
        }
    }
}

七、销毁链表

void desList(Node * head)
{
    head->pre->next = NULL;
    Node *t = NULL;
    while (head != NULL)
    {
        t = head;
        head = head->next;
        delete t;
    }
}

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

相关文章

  • C++深入探究不同的继承体系

    C++深入探究不同的继承体系

    继承是C++面向对象编程中的一门。继承是子类继承父类的特征和行为,或者是继承父类得方法,使的子类具有父类得的特性和行为。重写是子类对父类的允许访问的方法实行的过程进行重新编写,返回值和形参都不能改变。就是对原本的父类进行重新编写,但是外部接口不能被重写
    2022-05-05
  • strtok函数的使用示例

    strtok函数的使用示例

    今天小编就为大家分享一篇关于strtok函数的使用示例,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2018-12-12
  • 简单掌握桶排序算法及C++版的代码实现

    简单掌握桶排序算法及C++版的代码实现

    桶排序是将要排序的算法按桶分组排序之后再遍历汇总的一种线性排序算法,下面就让我们来通过小例子简单掌握桶排序算法及C++版的代码实现^^
    2016-07-07
  • C++11非受限联合体的使用

    C++11非受限联合体的使用

    本文主要介绍了C++11非受限联合体的使用,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-01-01
  • C语言代码实现简单扫雷小游戏

    C语言代码实现简单扫雷小游戏

    这篇文章主要为大家详细介绍了C语言实现扫雷游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-01-01
  • C/C++如何获取当前系统时间的实例详解

    C/C++如何获取当前系统时间的实例详解

    这篇文章主要介绍了 C/C++如何获取当前系统时间的实例详解的相关资料,这里提供了几种实现方法,帮助大家实现这样的功能,需要的朋友可以参考下
    2017-08-08
  • 用C语言完整实现2048游戏

    用C语言完整实现2048游戏

    2048是一款数字益智游戏,初始数字则是由2+2组成的基数4。在操作方面的不同则表现为一步一格的移动,变成更为爽快的一次到底。相同数字的方况在靠拢、相撞时会相加。系统给予的数字方块不是2就是4,玩家要想办法在这小小的16格范围中凑出2048这个数字方块
    2021-11-11
  • 详解C语言之柔性数组

    详解C语言之柔性数组

    这篇文章主要介绍了C语言柔性数组,通过实例分析了不完整类型、结构体及柔性数组等概念,需要的朋友可以参考下
    2021-11-11
  • C语言静态动态两版本通讯录实战源码

    C语言静态动态两版本通讯录实战源码

    这篇文章主要为大家带来了C语言实现静态动态两版本的通讯录实战源码,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步
    2022-02-02
  • C++深拷贝与浅拷贝的区别及应用

    C++深拷贝与浅拷贝的区别及应用

    这篇文章主要给大家介绍了关于C++深拷贝与浅拷贝区别及应用的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-04-04

最新评论