当前位置:  技术问答>linux和unix

链表操作

    来源: 互联网  发布时间:2016-09-30

    本文导语:  static  void __list_splice(struct list_head *list,  struct list_head *head) { struct list_head *first = list->next; struct list_head *last = list->prev; struct list_head *at = head->next; first->prev = head; head->next = first; last->next = at; at->prev = l...

static  void __list_splice(struct list_head *list,
 struct list_head *head)
{
struct list_head *first = list->next;
struct list_head *last = list->prev;
struct list_head *at = head->next;

first->prev = head;
head->next = first;

last->next = at;
at->prev = last;
}


谁能帮我解释下这段代码的意思?不甚感激啊!

|
static  void __list_splice(struct list_head *list,
                 struct list_head *head)
{
    struct list_head *first = list->next; //list下一结点
    struct list_head *last = list->prev;  //list上一结点
    struct list_head *at = head->next;    //head下一结点

    first->prev = head;
    head->next = first;//将head插入到list下一结点的上一结点,双向链表

    last->next = at;
    at->prev = last;//将head的下一结点插入到list上一结点的下一结点,双向链表
}

|


如果想详细,就去看数据结构的书吧

|
这个是标准的合并函数,把list合并到另一链表的head的后一个位置.双向循环链表

|
first 是指向list的head,而因为是循环链表 所以prev 指向的是list的末尾 也就是说last指向list的tail 以此类推 将两个链表合并

|
将head及下一节点代替list插入到list链表中,原先:list的上一节点--list--list下一个节点
替换后:list的上一节点--head的下一节点--head--list下一个节点。
以上都是双向链表。

|
普通的双向循环链表的合并操作

    
 
 

您可能感兴趣的文章:

 
本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • C++ Stacks(堆栈) 成员 操作:比较和分配堆栈
  • 谁有操作系统PV操作的例子???谁有操作系统PV操作的例子???谢谢!!
  • C++ Strings(字符串) 成员 Operators:操作符,用于字符串比较和赋值
  • 已安装了Windows操作系统,还想安装Linux。却还想在开机选择操作系统时由Windows引导,请问如何操作。在线等待
  • C++ I/O 成员 flags():操作flags
  • 请问LINUX操作系统是怎样对外围设备进行操作的
  • C++ I/O 成员 width():操作域宽度
  • 什么样的操作最耗费服务器的IO操作?
  • c#对象中两种copy操作:深拷贝(Deep Copy)与浅拷贝(Shallow Copy)
  • 无操作系统下对U盘的操作
  • NOSQL iis7站长之家
  • 请问命令行操作下怎么改Linux操作系统的日期和时间?
  • MyEclipse如何查看和设置文件编码格式相关操作
  • 正在学操作系统原理,做操作系统方面的实验用那种工具较好?
  • Html checkbox标签如何设置默认选中以及用js操作checkbox代码示例
  • 请问16位操作系统和32位操作系统的区别?
  • c/c++ 操作符优先级参考
  • 基于linux操作系统之上操作LCD问题,急???
  • javascript操作html复选框checkbox:如何判断复选框是否被选中
  • 哪位大侠知道Linux里的有名管道传送数据快不快?有名管道操作的过程是否有读写硬盘的操作?
  • Plesk 中操作和设置 Docker 容器
  • 如何在一个用户对application操作时防止别的用户对它操作?(好难啊)


  • 站内导航:


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

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

    浙ICP备11055608号-3