夏樾 2019-09-21 09:20 采纳率: 0%
浏览 467
已采纳

有谁讲解一下链表倒置的函数?

struct ListNode *reverse( struct ListNode *head )
{
struct ListNode *h=NULL, *p1, *p2=NULL;
p1=head;
while (p1 != NULL)
{
if (h == NULL)
{
h=(struct ListNode *)malloc(sizeof(struct ListNode));
h->data=p1->data;
h->next=NULL;
}
else
{
p2=(struct ListNode *)malloc(sizeof(struct ListNode));
p2->data=p1->data;
p2->next=h;
h=p2;
}
p1=p1->next;
}
return h;
}

  • 写回答

1条回答 默认 最新

  • threenewbee 2019-09-21 09:41
    关注

    遍历节点,每次开辟一个内存空间,把当前节点添加在复制出来的链表的开头,最后返回新复制出来的,就是颠倒的。
    比如原来是
    1-2-3-4
    首先找到1,新节点就是1
    然后找到2,就是2-1
    然后找到3,就是3-2-1
    最后找到4,就是4-3-2-1

    具体来说,如何插入到前面,就是

    p2=(struct ListNode *)malloc(sizeof(struct ListNode)); 创建节点
    p2->data=p1->data; 复制数据
    p2->next=h; 让新节点指向原来的链表的头
    h=p2; 将这个节点作为现在链表的头

    前面的if是对尾节点单独处理下。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 程序不包含适用于入口点的静态Main方法
  • ¥15 素材场景中光线烘焙后灯光失效
  • ¥15 请教一下各位,为什么我这个没有实现模拟点击
  • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
  • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置
  • ¥15 有没有研究水声通信方面的帮我改俩matlab代码
  • ¥15 ubuntu子系统密码忘记