题解 | #反转链表#

反转链表

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++)

全部评论

相关推荐

点赞 评论 收藏
分享
06-10 21:15
门头沟学院 Java
宁阿:好多这种没🧠的公司,他们估计都不知道毕业的人不能给安排实习岗
点赞 评论 收藏
分享
面了这么多场试,总有公司总喜欢压力面一个小时面试+手撕,哪里不会就点哪里,说了不会不会还继续追着问不尊重求职者,稍微有些细节记不清了,就开始怀疑项目真实性以及人格让求职者开摄像头但是自己不开,说话声音还贼小,pardon几次就开始不耐烦的不知道这个算不算,手撕的时候,面试官人跑了。。。最后快结束才来
一纸丿繁华丶:你换位思考一下,自己在职场被领导push麻了,身心俱疲,现在有个机会让你放松一下,体验一把上位者的感觉,还能看着那些高学历人才、未来自己的竞争者,抓耳挠腮、手足无措的样子,没给你当场笑出来就不错了,理解一下面试官吧。
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

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