码迷,mamicode.com
首页 > 其他好文 > 详细

双向链表的插入

时间:2015-08-21 20:51:45      阅读:137      评论:0      收藏:0      [点我收藏+]

标签:

问题:

    给定一个已排序的双向链表,向其中插入一个元素。

solution:

struct ListNode {
    int val;
    ListNode *prev;
    ListNode *next;
};

int insert(ListNode *head, int value)
{
    ListNode *cur;
    ListNode *next;
    for (cur = head; (next = cur->next) != NULL; cur = next)
    {
        if (next->val == value)
            return 0;
        if (next->val > value)
            break;
    }

    ListNode *newNode = new ListNode;
    newNode->val = value;

    newNode->next = next;
    cur->next = newNode;
    if (cur != head)
        newNode->prev = cur;
    else
        newNode->prev = NULL;
    if (next != NULL)
        next->prev = newNode;
    else
        head->prev = newNode;
    return 1;
}

有两点需要注意:

1. 声明一个头结点head,其中head->prev指向链表最后一个结点,head—>next指向链表第一个结点。

2. 当插入元素和链表中元素重复时,不执行插入操作。

 

reference:

《C和指针》

双向链表的插入

标签:

原文地址:http://www.cnblogs.com/gattaca/p/4748738.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!