夏樾 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是对尾节点单独处理下。

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

报告相同问题?

悬赏问题

  • ¥50 永磁型步进电机PID算法
  • ¥15 sqlite 附加(attach database)加密数据库时,返回26是什么原因呢?
  • ¥88 找成都本地经验丰富懂小程序开发的技术大咖
  • ¥15 如何处理复杂数据表格的除法运算
  • ¥15 如何用stc8h1k08的片子做485数据透传的功能?(关键词-串口)
  • ¥15 有兄弟姐妹会用word插图功能制作类似citespace的图片吗?
  • ¥200 uniapp长期运行卡死问题解决
  • ¥15 latex怎么处理论文引理引用参考文献
  • ¥15 请教:如何用postman调用本地虚拟机区块链接上的合约?
  • ¥15 为什么使用javacv转封装rtsp为rtmp时出现如下问题:[h264 @ 000000004faf7500]no frame?