剑指offer(15)反转链表

本文详细解析了链表反转的实现原理与步骤,通过具体的代码示例,展示了如何使用三个指针(pre、cur、tmp)来改变节点的指向,从而达到链表反转的目的。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

反转链表就是

先把当前节点所指向的原节点存起来,这里用tmp表示,此时tmp的值为2;

然后使当前节点指向前一个节点(cur.next=pre),然后将当前节点的值赋给pre(pre=cur);再然后就是使tmp为当前节点(cur=tmp)。

就是改变节点所指方向后,整体后移。

 

public class Solution {
    public ListNode ReverseList(ListNode head) {
        if(head==null)
            return null;
        ListNode cur=head;
        ListNode tmp=null;
        ListNode pre=null;
//反转链表,
        while(cur!=null){
//把cur.next的值存储起来
            tmp=cur.next;
//让cur指向pre
            cur.next=pre;
//然后将cur的值赋给pre
            pre=cur;
//现在的cur为tmp
            cur=tmp;
        }
        return pre;
    }
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值