一道算法题-不积跬步无以至千里

描述

给定一个单链表的头结点pHead(该头节点是有值的,比如在下图,它的val是1),长度为n,反转该链表后,返回新链表的表头。

一道笔试题 - 反转列表_链表

如当输入链表{1,2,3}时,
经反转后,原链表变为{3,2,1},所以对应的输出为{3,2,1}。
以上转换过程如下图所示:

预期结果

输入:
{1,2,3}

返回值:
{3,2,1}
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
输入:
{}

返回值:
{}

说明:
空链表则输出空    
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • 7.
  • 8.

代码

栈都是先进后出(FILO)

// http://javapub.net.cn

import java.util.Stack;
public class Solution
{
    public ListNode ReverseList(ListNode head)
    {
        Stack < ListNode > stack = new Stack < > ();
        //把链表节点全部摘掉放到栈中
        while(head != null)
        {
            stack.push(head);
            head = head.next;
        }
        if(stack.isEmpty()) return null;
        ListNode node = stack.pop();
        ListNode dummy = node;
        
        //栈中的结点全部出栈,然后重新连成一个新的链表
        while(!stack.isEmpty())
        {
            ListNode tempNode = stack.pop(); // 弹出
            node.next = tempNode;
            node = node.next;
        }
        //最后一个结点就是反转前的头结点,一定要让他的next,等于空,否则会构成环
        node.next = null;
        return dummy;
    }
}

  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • 7.
  • 8.
  • 9.
  • 10.
  • 11.
  • 12.
  • 13.
  • 14.
  • 15.
  • 16.
  • 17.
  • 18.
  • 19.
  • 20.
  • 21.
  • 22.
  • 23.
  • 24.
  • 25.
  • 26.
  • 27.
  • 28.
  • 29.
  • 30.
  • 31.