题解 | #反转链表#

反转链表

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

第一次在牛客上写题解,先那反转链表熟练一下吧。

1. 思路

那么,链表反转 应该怎么做呢?
最直接的想法应该是:
1)先遍历链表的元素,保存在stack中;
2)元素出栈,同时构建反转链表。
如此,则可以达到反转的目的。

但是,这样做,优雅吗?
显然不。要是可以在遍历的同时,就把反转链表给做了,岂不妙哉?!

一种可行的做法:
新建一个链表,这个链表有个头结点。
然后,遍历原链表,每当遍历一个原链表的值,就插入到这个伪头节点的后面。
如此,可以保证后面遍历的元素在新链表的前面。
即下述代码也。

2. 代码

public class Solution {
    public ListNode ReverseList(ListNode head) {
        ListNode cur = head;
        ListNode newHead = new ListNode(0);
        while (cur != null){
            ListNode tmp = new ListNode(cur.val);
            tmp.next = newHead.next;
            newHead.next = tmp;
            cur = cur.next;
        }
        return newHead.next;
    }
}

3. 结果

图片说明

解法补充:

空间复杂度为 O(1)的解法:

public class Solution {
    public ListNode ReverseList(ListNode head) {
        ListNode pre = null;
        ListNode cur = head;
        ListNode next = null;
        while(cur != null){
            next = cur.next;
            cur.next = pre;
            pre = cur;
            cur = next;
        }
        return pre;
    }
}

题目中提到的栈解法:

import java.util.Stack;
public class Solution {
    public ListNode ReverseList(ListNode head) {
        Stack<Integer> stack = new Stack<>();
        ListNode cur = head;
        while (cur!=null){
            stack.push(cur.val);
            cur = cur.next;
        }
        ListNode newHead = new ListNode(0);
        cur = newHead;
        while (!stack.isEmpty()){
            ListNode tmp = new ListNode(stack.pop());
            cur.next = tmp;
            cur = cur.next;
        }
        return newHead.next;
    }
}
全部评论

相关推荐

白火同学:先说结论,对于一份实习简历来说,整体还是挺不错的,技术深度和广度都到位,找到一份中小厂的实习没啥问题。 再说说能优化的点吧。 1、量化结果,项目中很多工作量化一下结果给面试官的感受会更直观一些,也能体现你对应用该项技术的理解(在众多技术为什么要用它,运行性能或者说开发效率往往是一大考虑指标;而不是说大家做这种功能都用它,所以我用它)。 2、突出亮点,项目中可以从“工作职责”择一些“个人亮点”另写一块,优先去写开发过程中遇到的xx问题,使用xx技术达到xx效果,针对性去写一些疑杂难的功能,能带出你个人思考和解决的过程。
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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