免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2247 | 回复: 4
打印 上一主题 下一主题

[C] 循环链表的逆序 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2009-04-15 15:16 |只看该作者 |倒序浏览
/* 双向循环链表,带头指针 */
struct list_node
{
    int data;
    struct list_node *prev, *next;
};

void list_reverse(struct list_node* head)
{
}

我糊涂了,双向的是不用反转的,逆序遍历就可
#define list_for_each_reverse(iter, head) \
    for (iter = (head)->prev; iter != (head); iter = iter->prev)

我实现的链表http://blog.chinaunix.net/u1/49865/showart.php?id=1901119

[ 本帖最后由 daxi1987 于 2009-4-15 21:06 编辑 ]

论坛徽章:
0
2 [报告]
发表于 2009-04-15 15:19 |只看该作者
#define prev next
#define next prev

论坛徽章:
0
3 [报告]
发表于 2009-04-15 18:41 |只看该作者
void list_reverse(struct list_node* head)
{
    if(head == NULL) return;
    else
    {
        list_reverse(head->next);
        struct list_node *prev = head->prev;
        head->prev = head->next;
        head->next = prev;
    }
}

先递归到末尾的节点,从该节点往首节点逆序

论坛徽章:
0
4 [报告]
发表于 2009-04-15 19:27 |只看该作者

回复 #3 bbmmzz 的帖子

这样不行

[ 本帖最后由 daxi1987 于 2009-4-15 21:07 编辑 ]

论坛徽章:
0
5 [报告]
发表于 2009-04-15 22:37 |只看该作者
第一个取下的结点next指针指向NULL,然后
依次取下的结点的next指针指向前一个取下的结点,而前一个取下的结点prev指针指向当前取下的结点就行了,一次遍历链表就搞定了.

[ 本帖最后由 converse 于 2009-4-15 22:40 编辑 ]
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP