。。。剑指Offer之——反转链表。。。

链表逆序算法解析
本文深入解析了一种链表逆序的算法实现过程,通过三个指针q、p、r的巧妙运用,实现了链表节点的逆序连接。文章详细介绍了算法的每一步操作,包括如何将当前节点的next指向前一个节点,以及节点指针的移动策略,最终返回逆序后的链表头节点。
 1 public ListNode ReverseList(ListNode head) {
 2         if (head == null) {
 3             return null;
 4         }
 5         if (head.next == null) {
 6             return head;
 7         }
 8 //        q表示前面一个节点指针
 9 //        p表示当前一个节点指针
10 //        r表示后面一个节点指针
11         ListNode q = null, p = head, r = p.next;
12 //        如果当前节点p不为空
13         while (p != null) {
14             p.next = q;//指向前面一个节点
15             q = p;//前面一个节点往后移动
16             p = r;//当前节点往后移动
17             if (r != null) {//最后一轮,r为空,不要再往后移动
18                 r = r.next;//后面一个节点往后移动
19             }
20         }
21 //        循环结束时,q是原来的最后一个节点,也就是反转之后的头节点
22         head = q;
23         return head;
24     }

 

转载于:https://www.cnblogs.com/yingmeng/p/10777890.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值