《算法通关村第二关——终于学会链表反转了》

方式一:建立虚拟头结点辅助反转

示例:

输入: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;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值