zoukankan      html  css  js  c++  java
  • 【剑指Offer】面试题24. 反转链表

    题目

    定义一个函数,输入一个链表的头节点,反转该链表并输出反转后链表的头节点。

    示例:

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

    限制:
    0 <= 节点个数 <= 5000

    注意:本题同【LeetCode】206. 反转链表

    思路一:反转链表元素

    取出链表中元素放入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;
    }
    
  • 相关阅读:
    ASCII、Unicode和UTF-8等常见字符编码格式介绍
    pycharm创建脚本头文件模板
    pycharm常用设置项和快捷键
    Genymotion安装apk问题
    [Android测试] Appium的一些坑问题错误解决 与 技巧集锦
    Appium+python自动化测试过程中问题
    python客户端和Appium服务端联调出现的问题解决办法
    移动端自动化测试环境搭建
    "http://127.0.0.1:4723/wd/hub"的解释
    wireshark抓包看ECN
  • 原文地址:https://www.cnblogs.com/galaxy-hao/p/12343596.html
Copyright © 2011-2022 走看看