文章目录
- 描述
- 预期结果
- 代码
描述
给定一个单链表的头结点pHead(该头节点是有值的,比如在下图,它的val是1),长度为n,反转该链表后,返回新链表的表头。
如当输入链表{1,2,3}时,
经反转后,原链表变为{3,2,1},所以对应的输出为{3,2,1}。
以上转换过程如下图所示:
预期结果
输入:
{1,2,3}
返回值:
{3,2,1}
输入:
{}
返回值:
{}
说明:
空链表则输出空
代码
栈都是先进后出(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;
}
}