zoukankan      html  css  js  c++  java
  • 【LeetCode】206. 反转链表

    题目

    反转一个单链表。

    示例:

    输入: 1->2->3->4->5->NULL
    输出: 5->4->3->2->1->NULL
    

    进阶:
    你可以迭代或递归地反转链表。你能否用两种方法解决这道题?

    注意:本题同【剑指Offer】面试题24. 反转链表

    思路一:反转链表元素

    取出链表中元素放入vector中,然后将vector中元素逆向存入链表中。

    1. 遍历链表,用vector存放数组元素。
    2. 再次遍历链表,从vector尾部读取元素依次放入链表中。

    代码

    时间复杂度:O(n)
    空间复杂度:O(n)

    ListNode* reverseList(ListNode* head) {
        if (head == nullptr) {
            return head;
        }
        vector<int> res;        
        ListNode *pNode = head;
        while (pNode != nullptr) {
            res.push_back(pNode->val);
            pNode = pNode->next;
        }
        vector<int>::reverse_iterator iter = res.rbegin();
        pNode = head;
        while (pNode != nullptr) {
            pNode->val = *iter;
            iter++;
            pNode = pNode->next;
        }
        return head;
    }
    

    思路二:迭代

    需要调整当前元素指针指向前一个元素,必须先存储其前一个元素,另外为了继续遍历链表,在改动指针前,还需要存储下一个节点。新头结点为最后保存的前一个元素。

    代码

    时间复杂度:O(n)
    空间复杂度:O(1)

    ListNode* reverseList(ListNode* head) {
        if (head == nullptr) {
            return head;
        }
        ListNode *cur = head;
        ListNode *pre = nullptr;
        while (cur != nullptr) {
            ListNode *next = cur->next;//保存当前节点下一个节点
            cur->next = pre;//反转指针
            pre = cur;//分别移动pre和cur
            cur = next;
        }
        return pre;
    }
    

    思路三:递归

    通过递归反转链表后面的元素,递归终止条件为当前节点为空或下一个节点为空。现在对头节点进行反转,假设链表此时为:
    head -> n1 <- n2... <-n
    对头结点进行反转:head->next->next = head;
    然后将头节点next设为nullptr。

    代码

    时间复杂度:O(n)
    空间复杂度:O(n),由于使用递归,会使用隐式栈空间,递归深度可能达到n层。

    ListNode* reverseList(ListNode* head) {
        if (head == nullptr || head->next == nullptr) {
            return head;
        }
        ListNode *p = reverseList(head->next);
        head->next->next = head;
        head->next = nullptr;
        return p;
    }
    
  • 相关阅读:
    java基础(六):RabbitMQ 入门
    Spring Boot 入门(六):集成 treetable 和 zTree 实现树形图
    Geoserver+Openlayers拉框查询
    Spring Boot 入门(五):集成 AOP 进行日志管理
    Spring boot 入门(四):集成 Shiro 实现登陆认证和权限管理
    java基础(五):谈谈java中的多线程
    java基础(四):谈谈java中的IO流
    java基础(三):谈谈java异常的处理
    java基础(二):谈谈Java基本数据结构
    Java编译时常量和运行时常量
  • 原文地址:https://www.cnblogs.com/galaxy-hao/p/12343616.html
Copyright © 2011-2022 走看看