Leetcode - Reverse Linked List

Question:
Reverse a singly linked list.

My code

/**  iteration
 * Definition for singly-linked list.
 * public class ListNode {
 *     int val;
 *     ListNode next;
 *     ListNode(int x) { val = x; }
 * }
 */
public class Solution {
    public ListNode reverseList(ListNode head) {
        if (head == null)
            return null;
        doubleLinkedList doubleHead = new doubleLinkedList(head.val);
        ListNode temp = head;
        while (temp.next != null) {
            doubleHead.next = new doubleLinkedList(temp.next.val);
            doubleHead.next.prev = doubleHead;
            doubleHead = doubleHead.next;
            temp = temp.next;
        }
        
        ListNode reverseListHead = new ListNode(doubleHead.val);
        ListNode reverseTemp = reverseListHead;
        while (doubleHead.prev != null) {
            reverseTemp.next = new ListNode(doubleHead.prev.val);
            doubleHead = doubleHead.prev;
            reverseTemp = reverseTemp.next;
        }
        
        return reverseListHead;
    }
    
    private class doubleLinkedList {
        int val;
        doubleLinkedList next;
        doubleLinkedList prev;
        doubleLinkedList(int x) { val = x;}
    }
}
/** reversion
 * Definition for singly-linked list.
 * public class ListNode {
 *     int val;
 *     ListNode next;
 *     ListNode(int x) { val = x; }
 * }
 */
public class Solution {
    public ListNode reverseList(ListNode head) {
        if (head == null)
            return null;
        ListNode tail = head;
        while (tail.next != null)
            tail = tail.next;
        reverseListNode(head);
        return tail;
    }
    
    private void reverseListNode(ListNode node) {
        if (node.next == null)
            return;
        reverseListNode(node.next);
        node.next.next = node;
        node.next = null;
        
    }
    
    public static void main(String[] argv) {
        ListNode node1 = new ListNode(1);
        ListNode node2 = new ListNode(2);
        ListNode node3 = new ListNode(3);
        ListNode node4 = new ListNode(4);
        node1.next = node2;
        node2.next = node3;
        node3.next = node4;
        node4.next = null;
        Solution test = new Solution();
        ListNode head = test.reverseList(node1);
        while (head != null) {
            System.out.println(head.val);
            head = head.next;
        }
    }
    
}
  

My test result:
iteration:

Paste_Image.png

reversion:

Paste_Image.png

**
总结:
这次作业比较简单。用两种方式实现,一种是循环,一种是递归。
循环的思想比较简单,我是先另建一个双向链表,然后把单向链表存到双向链表,之后再把双向链表存到一个新的单向链表中,并返回。或者也可以用数组来实现,把链表结点存入数组,并且不断地resize,存入所有结点,在倒序构造一个新的单向链表。
递归的话,就是把这个链表当做两个部分,当前结点和当前结点之后的那段链表。先把之后的那段链表倒置,再和这个结点倒置。然后不断得递归。
作业还是比较简单的,还是要坚持每天一题。
毕业季,好冷清啊。希望今晚可以闹起来。
**

差不多的做法。
Anyway, Good luck, Richardo! -- 08/15/2016

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • My code: My test result: 这道题目一开始理解错题意了。。真是啃爹。然后,以前反转链表,我都...
    Richardo92阅读 338评论 0 1
  • My code: 这道题目用两种方法实现了反转链表。一种是直接遍历,一边遍历一边反转。一种是,用递归实现反转。 A...
    Richardo92阅读 220评论 0 0
  • 1.把二元查找树转变成排序的双向链表 题目: 输入一棵二元查找树,将该二元查找树转换成一个排序的双向链表。 要求不...
    曲终人散Li阅读 3,388评论 0 19
  • 大学的时候不好好学习,老师在讲台上讲课,自己在以为老师看不到的座位看小说,现在用到了老师讲的知识,只能自己看书查资...
    和珏猫阅读 1,486评论 1 3
  • 愿时光带走那一抹往事, 愿清泉洗涤那一片浑浊, 愿那一缕阳光带走你心灵的忧愁, 愿你安好 在那波涛起伏的海面上, ...
    路灯下的愿人阅读 290评论 0 0