反转链表

一道简单的题目,下面直接贴代码,思路在注释中

import java.util.ArrayList;
import java.util.List;

/**
 * 反转链表
 * 输入一个链表,反转链表后,输出新链表的表头
 *
 * 解题思路:
 * 遍历两次,使用数组。第一次遍历所有,并按顺序全部放入数组中;
 * 第二次遍历,实现反转链表
 *
 * 要注意的地方:
 * 当head为null时,可能存在数组下标的问题,要注意以下第二次遍历的反转过程
 *
 * @author ihaokun
 * @date 2019/7/23 21:10
 */
public class ReverseLinkedList {
    public static void main(String[] args) {
        /*ListNode head = new ListNode(1);
        head.next = new ListNode(2);
        head.next.next = new ListNode(3);*/
        ListNode head = null;
       head = reverse(head);
        while (head != null) {
            System.out.println(head.val);
            head = head.next;
        }
    }

    public static ListNode reverse(ListNode head) {
        List<ListNode> array = new ArrayList<>();
        while (head != null) {
            array.add(head);
            head = head.next;
        }
        if (array.size() > 0) {
            for (int i = array.size() - 1; i > 0; i--) {
                array.get(i).next = array.get(i - 1);
            }
            array.get(0).next = null;
            return array.get(array.size() - 1);
        }
        return null;
    }

    static class ListNode {
        int val;
        ListNode next = null;

        ListNode(int val) {
            this.val = val;
        }
    }
}

 

posted @ 2019-07-23 21:41  AloeAndClover  阅读(196)  评论(0编辑  收藏  举报