方式一:建立虚拟头结点辅助反转
示例:
输入:head=[1,2,3,4,5]
输出:[5,4,3,2,1]
实现思路:如下图,ans为虚拟头节点。
具体实现代码:
//定义方法reverseNode()实现链表的反转
private static Node reverseNode(Node headNode) {
Node ans = new Node(0);
ans.nextNode = headNode;
Node cur = headNode;
while(cur != null) {
Node next = cur.nextNode;
cur.nextNode = ans.nextNode;
ans.nextNode = cur;
cur = next;
}
return ans.nextNode;
}
//结点的定义
class Node{
public int data;
public Node nextNode;
public Node(int data) {
this.data = data;
}
}
方式二:直接操作链表实现反转
示例:
输入:head=[1,2,3,4,5]
输出:[5,4,3,2,1]
实现思路:
反转即是头节点指向null,原来头结点的下一个节点指向头节点,依次类推
如果头节点直接指向null的话会导致后面的节点直接丢失,所以要用一个节点来代替头结点做反转,最后返回值返回该节点作为头结点。
利用迭代:使用双指针实现
初始化一个指针cur指向头节点,另一个指针pre指向null,
每次循环需要一个临时节点temp获取当前节点的下一个节点,保证连续,
第一次循环,temp获取头节点的下一个节点:temp=cur.next
获取完之后头节点要变成尾节点即cur.next = pre,
这时候指向null的pre指针需要指向头节点(原因是原头结点要被第2个节点指向)即pre = cur 原先指向头结点的cur指针就需要指向我们获取的第2个节点,而第二个节点已经被我们用临时节点取出来了,即cur=temp.
如此迭代,当cur指向null时也就是到了原先的尾节点就跳出循环,返回pre。
具体实现代码:
//定义结点
class Node{
public int data;
public Node nextNode;
public Node(int data) {
this.data = data;
}
}
//定义一个方法reverseNode()实现链表的反转.
private static Node reverseNode(Node headNode){
Node pre = null;
Node cur = headNode;
while(cur != null){
Node temp = cur.nextNode;
cur.nextNode = pre;
pre = cur;
cur = temp;
}
return pre;
}