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;
}
有谁讲解一下链表倒置的函数?
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
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子系统密码忘记