java 循环链表倒置_【算】链表反转

问题

最近研究算法,遇到的一道很有意思的问题——怎么把一个链表反转?

很容易想到一个方法:遍历链表,数组作栈存储路径,元素逐个出栈得到的就是反转后的链表!查找资料发现,有更好的方式实现。

仔细研究后,终于明白了其中的奥妙。小僧掌握了两种方法,以下分别进行说明。

de55eb74917cf9b45fcc3316cdf4ff24.png

首先给出链表结构:

public class LinkedNode {

Integer id ;

LinkedNode next;

public LinkedNode(Integer id) {

this.id = id;

}

}

下一步构造出上图的链表结构:

LinkedNode node1 = new LinkedNode(1);

LinkedNode node2 = new LinkedNode(2);

LinkedNode node3 = new LinkedNode(3);

LinkedNode node4 = new LinkedNode(4);

node1.next = node2;

node2.next = node3;

node3.next = node4;

双指针遍历法

先给出代码实现:

/**

* 链表翻转,循环 + 双指针(pre、next)实现

* @param cur

* @return

*/

public LinkedNode reverse(LinkedNode cur){

LinkedNode pre = null;

while (cur!=null){

LinkedNode next = cur.next; // 1.

cur.next = pre; // 2.

pre = cur; // 3.

cur = next; // 4.

}

return pre;

}

循环体之前,链表示意图:

febf9ccbdde8ae291e936f49a9a49964.png

之后进入while循环,注释标注的四个步骤会产生如下变化(图中编号与注释编号一一对应):

cfd128f78c2a3adcb1302db84583b2d5.png

第一次循环后,链表变成这样:

6fd36f0fe0d2c320ddd0b3a2f8bb0235.png

之后的遍历,链表的变化示意:

f01d6a7abb8b41818406e10c844f9b47.png

可见,while循环执行完,pre指向的节点,已经是最新的头节点了!

递归法

递归的实现方式,似乎更容易理解。

/**

* 链表反转,递归实现

* @param node

* @return

*/

public LinkedNode reverse2(LinkedNode node){

if(node.next==null){

return node;

}

LinkedNode newHead = reverse2(node.next);

node.next.next = node; //node.next.next 换成 newHead.next 不行,因为node在递归中在追溯上一个节点,仔细体会下

node.next = null;

return newHead;

}

首先会通过递归调用找到尾节点,之后做了两件事:

尾节点反指 (node.next.next = node;)

当前节点指向null节点 (node.next = null;)

99cc98be0963dc6f17fafd07e8a6d9a9.png

rentun newHead后,回溯到节点2(此时node就是节点2),再次重复之前的两件事——节点反指和当前节点指向null节点。

8600d32e9b40563cc5f59901b57c8d5b.png

再次回溯,得到最终的结果。

d959027c6c8ccd522eabb917d768f1fc.png

Done !

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值