反转链表
给你单链表的头节点 head
,请你反转链表,并返回反转后的链表。
想法一:将需要反转的链表建立一个空头,再逐一进行反转:
class Solution { public: ListNode* reverseList(ListNode* head) { ListNode* slow = NULL; ListNode* fast = head; while (fast != NULL) { ListNode* next = fast->next; fast->next = slow; slow = fast; fast = next; } return slow; } };
想法二:若是不建立空头:这种方法不可行的,因为执行第一部的第二个节点的next指针指向第一个节点的时候,第一个节点的next指针还是指向第二个节点,所以第一个节点的next还是要指向空的,还是回到第一种方法。
【推荐】博客园的心动:当一群程序员决定开源共建一个真诚相亲平台
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】Flutter适配HarmonyOS 5知识地图,实战解析+高频避坑指南
【推荐】开源 Linux 服务器运维管理面板 1Panel V2 版本正式发布
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步