当前位置:  编程技术>c/c++/嵌入式

c++双向链表操作示例(创建双向链、双向链表中查找数据、插入数据等)

    来源: 互联网  发布时间:2014-10-25

    本文导语:  双向链表也叫双链表,是链表的一种,它的每个数据结点中都有两个指针,分别指向直接后继和直接前驱。所以,从双向链表中的任意一个结点开始,都可以很方便地访问它的前驱结点和后继结点。一般我们都构造双向循环链...

双向链表也叫双链表,是链表的一种,它的每个数据结点中都有两个指针,分别指向直接后继和直接前驱。所以,从双向链表中的任意一个结点开始,都可以很方便地访问它的前驱结点和后继结点。一般我们都构造双向循环链表。

(1)定义双向链表的基本结构

代码如下:

typedef struct _DOUBLE_LINK_NODE 

    int data; 
    struct _DOUBLE_LINK_NODE* prev; 
    struct _DOUBLE_LINK_NODE* next; 
}DOUBLE_LINK_NODE; 

(2)创建双向链表节点

代码如下:

DOUBLE_LINK_NODE* create_double_link_node(int value) 

    DOUBLE_LINK_NODE* pDLinkNode = NULL; 
    pDLinkNode = (DOUBLE_LINK_NODE*)malloc(sizeof(DOUBLE_LINK_NODE)); 
    assert(NULL != pDLinkNode); 

    memset(pDLinkNode, 0, sizeof(DOUBLE_LINK_NODE)); 
    pDLinkNode->data = value; 
    return pDLinkNode; 

(3)删除双向链表

代码如下:

void delete_all_double_link_node(DOUBLE_LINK_NODE** pDLinkNode) 

    DOUBLE_LINK_NODE* pNode; 
    if(NULL == *pDLinkNode) 
        return ; 

    pNode = *pDLinkNode; 
    *pDLinkNode = pNode->next; 
    free(pNode); 
    delete_all_double_link_node(pDLinkNode); 
}

(4)在双向链表中查找数据

代码如下:

DOUBLE_LINK_NODE* find_data_in_double_link(const DOUBLE_LINK_NODE* pDLinkNode, int data) 

    DOUBLE_LINK_NODE* pNode = NULL; 
    if(NULL == pDLinkNode) 
        return NULL; 

    pNode = (DOUBLE_LINK_NODE*)pDLinkNode; 
    while(NULL != pNode){ 
        if(data == pNode->data) 
            return pNode; 
        pNode = pNode ->next; 
    } 

    return NULL; 

(5)双向链表中插入数据

代码如下:

STATUS insert_data_into_double_link(DOUBLE_LINK_NODE** ppDLinkNode, int data) 

    DOUBLE_LINK_NODE* pNode; 
    DOUBLE_LINK_NODE* pIndex; 

    if(NULL == ppDLinkNode) 
        return FALSE; 

    if(NULL == *ppDLinkNode){ 
        pNode = create_double_link_node(data); 
        assert(NULL != pNode); 
        *ppDLinkNode = pNode; 
        (*ppDLinkNode)->prev = (*ppDLinkNode)->next = NULL; 
        return TRUE; 
    } 

    if(NULL != find_data_in_double_link(*ppDLinkNode, data)) 
        return FALSE; 

    pNode = create_double_link_node(data); 
    assert(NULL != pNode); 

    pIndex = *ppDLinkNode; 
    while(NULL != pIndex->next) 
        pIndex = pIndex->next; 

    pNode->prev = pIndex; 
    pNode->next = pIndex->next; 
    pIndex->next = pNode; 
    return TRUE; 

(6)双向链表中删除数据

代码如下:

STATUS delete_data_from_double_link(DOUBLE_LINK_NODE** ppDLinkNode, int data) 

    DOUBLE_LINK_NODE* pNode; 
    if(NULL == ppDLinkNode || NULL == *ppDLinkNode) 
        return FALSE; 

    pNode = find_data_in_double_link(*ppDLinkNode, data); 
    if(NULL == pNode) 
        return FALSE; 

    if(pNode == *ppDLinkNode){ 
        if(NULL == (*ppDLinkNode)->next){ 
            *ppDLinkNode = NULL; 
        }else{ 
            *ppDLinkNode = pNode->next; 
            (*ppDLinkNode)->prev = NULL; 
        } 

    }else{ 
        if(pNode->next) 
            pNode->next->prev = pNode->prev; 
        pNode->prev->next = pNode->next; 
    } 

    free(pNode); 
    return TRUE; 

(7)统计双向链表中数据的个数

代码如下:

int count_number_in_double_link(const DOUBLE_LINK_NODE* pDLinkNode) 

    int count = 0; 
    DOUBLE_LINK_NODE* pNode = (DOUBLE_LINK_NODE*)pDLinkNode; 

    while(NULL != pNode){ 
        count ++; 
        pNode = pNode->next; 
    } 
    return count; 

(8)打印双向链表中数据

代码如下:

void print_double_link_node(const DOUBLE_LINK_NODE* pDLinkNode) 

    DOUBLE_LINK_NODE* pNode = (DOUBLE_LINK_NODE*)pDLinkNode; 

    while(NULL != pNode){ 
        printf("%dn", pNode->data); 
        pNode = pNode ->next; 
    } 

今天我们讨论的双向链表是非循环的,大家可以考虑一下如果改成循环双向链表,应该怎么写?如果是有序的循环双向链表,又该怎么写?


    
 
 

您可能感兴趣的文章:

  • C++ Double Ended Queues(双向队列) 成员 empty():返回真如果双向队列为空
  • C++ 模版双向链表的实现详解
  • C++ Double Ended Queues(双向队列) 成员 Operators:比较和赋值双向队列
  • 如何用C++实现双向循环链表
  • C++ Double Ended Queues(双向队列) 成员 resize():改变双向队列的大小
  • C++ 构造双向链表的实现代码
  • C++ Double Ended Queues(双向队列) 成员 swap():和另一个双向队列交换元素
  • C++ Double Ended Queues(双向队列) 成员 size():返回双向队列中元素的个数
  • C++ Double Ended Queues(双向队列) 成员 assign():设置双向队列的值
  • C++ Double Ended Queues(双向队列) 成员 get_allocator():返回双向队列的配置器
  • C++ Double Ended Queues(双向队列) 成员 insert():插入一个元素到双向队列中
  • C++ Double Ended Queues(双向队列) 成员 max_size():返回双向队列能容纳的最大元素个数
  • C++ Double Ended Queues(双向队列) 成员 Constructors:创建一个新双向队列
  • C++ Double Ended Queues(双向队列) 成员 at():返回指定的元素
  • C++ Double Ended Queues(双向队列) 成员 back():返回最后一个元素
  • C++ Double Ended Queues(双向队列) 成员 clear():删除所有元素
  • C++ Double Ended Queues(双向队列) 成员 end():返回指向尾部的迭代器
  • C++ Double Ended Queues(双向队列) 成员 front():返回第一个元素
  • C++ Double Ended Queues(双向队列) 成员 rend():返回指向头部的逆向迭代器
  • C++ Double Ended Queues(双向队列) 成员 rbegin():返回指向尾部的逆向迭代器
  • C++ Double Ended Queues(双向队列) 成员 begin():返回指向第一个元素的迭代器
  • JavaScript 双向数据绑定库 Way.js
  • 客户机和服务器可以双向收发数据的socket编程
  • 客户端程序和服务器程序间能否通过管道来实现数据的双向传递啊?
  • 双向数据绑定JS库 Bindable.js
  • MySQL 数据库双向镜像、循环镜像(复制)
  • 为什么libnids只能捕获单向数据流,而不是双向的
  • java数据结构之实现双向链表的示例
  • C#数据结构与算法揭秘四 双向链表
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • C++ Double Ended Queues(双向队列) 成员 push_back():在尾部加入一个元素
  • C语言双向链表 Doubly Linked List
  • 双向队列Deque 类成员函数列表参考(c++ STL 容器)
  • PHP双向队列实现代码
  • c++类库Boost::bimap(双向映射)介绍及使用实例
  • socket双向通讯模式请教
  • C#实现https双向认证的实例代码
  • 为什么linux与windows电脑连接非常慢,双向都是!
  • 如何在使用嵌入式Linux的设备中通过USB端口与PC进行双向通信
  • mysql 双向同步的键值冲突问题的解决方法分享
  • codeigniter集成ucenter1.6双向通信的解决办法
  • mysql双向加密解密方式用法详解
  • PHP小教程之实现双向链表
  • Datagram Scoket双向通信
  • 深入多线程之:双向信号与竞赛的用法分析
  • 怎么实现server和client双向聊天的SOCKET,我哪错了
  • python双向链表实现实例代码
  • Java语言中链表和双向链表
  • C语言双向链表的表示与实现实例详解
  • 双向链表插入删除基本应用介绍
  • Hibernate一对多关联双向关联代码实现分享


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3