题解 | #反转链表#

反转链表

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

第一种方法:利用双指针迭代求解

时间复杂度为:o(n)

空间复杂度为:o(1)

class Solution {
public:
    ListNode* ReverseList(ListNode* head) {
        if(head == nullptr)
            return nullptr;
        
        while(head != nullptr) {
            pNext = head->next;
            head->next = pTemp;
            pTemp = head;
            head = pNext;
        }
        return pTemp;
    }
private:
    ListNode* pTemp = nullptr;
    ListNode* pNext = nullptr;
};

第二种方法:使用递归求解

时间复杂度为:o(n)

空间复杂度为:o(n)

class Solution {
public:
    ListNode* ReverseList(ListNode* head) {
         if(head == nullptr || head->next == nullptr)
            return head;
        //反转下一个
        ListNode* newHead = ReverseList(head->next);
        //逆转本级节点
        head->next->next = head;
        //尾部设置空节点
        head->next = nullptr;
        return newHead;
    }
};

第三种方法:利用栈来求解

时间复杂度为:o(n)

空间复杂度为:o(n)

不符合题目的要求,但也提供出来开阔视野

class Solution {
public:
    ListNode* ReverseList(ListNode* head) {
        p = head;
        if (nullptr == head || nullptr == head->next) 
            return head;

        while (p!= nullptr) {//将链表元素入栈
            sk.push(p) ;
            p = p->next;
        }

        newhead = sk.top();
        sk.pop ();
        temp = newhead;
        while (!sk.empty()) {
            temp->next = sk.top();
            temp = temp->next;
            sk.pop ();
        }
        temp->next = nullptr;
        return newhead;
    }
private:
    stack<ListNode*> sk;
    ListNode* p;
    ListNode* newhead;
    ListNode* temp;
};

刷题题解(c++) 文章被收录于专栏

算法题题解(c++)

全部评论

相关推荐

评论
1
收藏
分享

创作者周榜

更多
正在热议
更多
# 一张图晒出你司的标语 #
4472次浏览 78人参与
# 找AI工作可以去哪些公司? #
10192次浏览 322人参与
# 开放七大实习专项,百度暑期实习值得冲吗 #
15780次浏览 230人参与
# 你的实习产出是真实的还是包装的? #
20951次浏览 346人参与
# 从事AI岗需要掌握哪些技术栈? #
9889次浏览 397人参与
# 春招至今,你的战绩如何? #
68165次浏览 603人参与
# 厦门银行科技岗值不值得投 #
8264次浏览 188人参与
# AI面会问哪些问题? #
29225次浏览 638人参与
# 你做过最难的笔试是哪家公司 #
36179次浏览 319人参与
# 中国电信笔试 #
32411次浏览 302人参与
# 金三银四,你的春招进行到哪个阶段了? #
22601次浏览 284人参与
# 投递几十家公司,到现在0offer,大家都一样吗 #
341263次浏览 2176人参与
# 同bg的你秋招战况如何? #
212268次浏览 1121人参与
# 哪些公司真双非友好? #
69844次浏览 289人参与
# 如何准备秋招 #
78326次浏览 868人参与
# 阿里笔试 #
179514次浏览 1324人参与
# 应届生被毁约被毁意向了怎么办 #
63364次浏览 305人参与
# 机械人避雷的岗位/公司 #
62728次浏览 393人参与
# 小马智行求职进展汇总 #
25151次浏览 80人参与
# 第一份工作一定要去大厂吗 #
15303次浏览 129人参与
# 担心入职之后被发现很菜怎么办 #
291438次浏览 1210人参与
# 为了减少AI幻觉,你注入过哪些设定? #
26336次浏览 310人参与
牛客网
牛客网在线编程
牛客网题解
牛客企业服务