循环链表跟普通单链表相比,其不同之处,就在于,循环链表最后一个元素并非指向NULL,而是指向了头结点,这样一来,就将整个链表串成了一个环。
那么,这个循环链表有什么用呢?它解决了从任意一个结点出发,访问整个链表的问题。
还有一个不同之处就是,遍历链表不用头指针,而用尾指针rear。则访问第一元素的结点为,
rear->next->next;
循环链表还有一个重要运用就是,将两个链表合并。假设有两个链表A和B,如何实现这两个链表的合并呢?只要将链表A的尾部指向链表B的头部,将链表B的尾部指向A的头部,就行了。代码如下:
p = rearA->next;
rearA->next = rearB->next->next;
q = rearB->next;
rearB->next = p;
free(q);
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。