反转链表
`/**
- Definition for singly-linked list.
- struct ListNode {
-
int val;
-
struct ListNode *next;
- };
*/
struct ListNode* reverseList(struct ListNode* head){
struct ListNode* newhead = NULL,tmp;
while(head){
/ tmp = head->next;
head->next = newhead;
newhead = head;
head = tmp;//保存head->next,接下来将1独立拿出来,head->next = NULL;*/
tmp = head;
head = head->next;
tmp->next = newhead;
newhead = tmp;
}
return newhead;
}`
如果tmp = head->next和tmp = head区别在于前者保存了下一个结点,而后者是暂存当前结点,所以后者不能上来就head->next = newhead,会丢失后面下一个结点。
两个写法的newhead含义恰恰相反,前者newhead是暂存当前结点,后者由于头节点已经向后移动了,导致newhead暂存的是下一结点。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 【杭电多校比赛记录】2025“钉耙编程”中国大学生算法设计春季联赛(1)