题解 | #反转链表#

反转链表

https://www.nowcoder.com/practice/75e878df47f24fdc9dc3e400ec6058ca

/*
struct ListNode {
	int val;
	struct ListNode *next;
	ListNode(int x) :
			val(x), next(NULL) {
	}
};*/
#include <cstddef>
class Solution {
public:
   ListNode* ReverseList(ListNode* pHead) {
   if(pHead==nullptr) return nullptr;//if null
   if(pHead->next== nullptr) return pHead;//if only head
   ListNode* last=ReverseList(pHead->next);//从整体功能推测局部
   pHead->next->next=pHead;//将phead后一个元素指针逆转
   pHead->next=nullptr;//phead设置为空
   return last;
    }
};

根据Labuladong算法小抄给的递归思路解决。

ReverseList(phead)功能是将整个链表逆转,并返回指向最末结点作为头结点;那ReverseList(phead->next)功能是将除phead结点以外链表逆转,并返回该部分链表的最末结点指针作为头结点;再将phead和剩余链表部分指针进行逆转;将phead指向空,作为末结点即可。

#菜鸟的编程学习#
全部评论

相关推荐

11-13 10:17
门头沟学院 Java
昨天面美团,jvm,juc问的好深啊,感觉小林coding不太够喔,牛油们有没有什么推荐的八股网站嘛🕒&nbsp;岗位/面试时间👥&nbsp;面试题目🤔&nbsp;面试感受
明天不下雨了:小林Coding:https://xiaolincoding.com/ 全栈哥:https://www.pdai.tech/ Guide哥:https://javaguide.cn/ 秀哥:https://interviewguide.cn/ 沉默王二:https://javabetter.cn/home.html 磊哥:https://www.javacn.site/interview/basic/ 小傅哥:https://bugstack.cn/ 源码哥:https://doocs.github.io/source-code-hunter/#/ 各大厂的公众号技术文章和一些经典的书籍
面试太紧张了怎么办?
点赞 评论 收藏
分享
代码飞升_不回私信人...:啊喂笨蛋算法为什么写查找,线程池怎么放计网上去了,写动态规划真的不会被狠狠地制裁吗oi
点赞 评论 收藏
分享
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务