题解 | 反转链表

反转链表

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

解题思路

  1. 使用三个指针:

    • prev:指向前一个节点
    • curr:指向当前节点
    • next:指向下一个节点
  2. 反转步骤:

    • 保存当前节点的下一个节点(next = curr.next)
    • 反转当前节点的指针(curr.next = prev)
    • 移动prev和curr指针
      • prev = curr
      • curr = next
  3. 特殊情况处理:

    • 空链表:直接返回null
    • 单节点链表:直接返回该节点

代码

class Solution {
public:
    ListNode* ReverseList(ListNode* pHead) {
        // 如果链表为空或只有一个节点,直接返回
        if (!pHead || !pHead->next) {
            return pHead;
        }
        
        ListNode* prev = nullptr;
        ListNode* curr = pHead;
        ListNode* next = nullptr;
        
        while (curr) {
            // 保存下一个节点
            next = curr->next;
            // 反转当前节点的指针
            curr->next = prev;
            // 移动prev和curr指针
            prev = curr;
            curr = next;
        }
        
        return prev;
    }
};
public class Solution {
    public ListNode ReverseList(ListNode head) {
        // 如果链表为空或只有一个节点,直接返回
        if (head == null || head.next == null) {
            return head;
        }
        
        ListNode prev = null;
        ListNode curr = head;
        ListNode next = null;
        
        while (curr != null) {
            // 保存下一个节点
            next = curr.next;
            // 反转当前节点的指针
            curr.next = prev;
            // 移动prev和curr指针
            prev = curr;
            curr = next;
        }
        
        return prev;
    }
}
class Solution:
    def ReverseList(self, head):
        # 如果链表为空或只有一个节点,直接返回
        if not head or not head.next:
            return head
            
        prev = None
        curr = head
        
        while curr:
            # 保存下一个节点
            next = curr.next
            # 反转当前节点的指针
            curr.next = prev
            # 移动prev和curr指针
            prev = curr
            curr = next
            
        return prev

算法及复杂度分析

  • 算法:链表的基本操作

  • 时间复杂度:

    • 只需要遍历一次链表
    • 是链表的长度
  • 空间复杂度:

    • 只使用了三个指针变量
    • 不需要额外的存储空间

这个解法的优点是:

  1. 实现简单直观
  2. 空间复杂度为
  3. 只需要一次遍历
  4. 不需要额外的数据结构
全部评论

相关推荐

昨天 16:39
已编辑
门头沟学院 测试开发
点赞 评论 收藏
分享
码砖:求职岗位要突出,一眼就能看到,教育背景放到最后,学校经历没那么重要,项目要重点突出
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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