链表:反转链表

反转链表

反转链表,常用的方法有迭代,栈反转,递归反转。

迭代

比如,现有链表1->2->3->4->5,

首先,从第一个节点开始,反转,将1->null,

接着向下一个节点2,迭代,反转,将2->1,

接着向下一个节点3,迭代,反转,将3->2,也就是变成了3->2->1,依此类推。

关键的几点:

复制代码
1.找到当前节点、上一个节点;
2.反转。将当前节点指向上一个节点,形成反转;
3.迭代。向后迭代,找到新的"当前节点"、"上一个节点"。

如下:

复制代码
public ListNode reserveListNode(ListNode head)  {
    //上一个节点
	ListNode prev=null;
    //当前节点
	ListNode curr=head;
    //当前节点不为null,就循环
    while( curr!=null) {
        //先记住下一个节点
		ListNode nextNode= curr.next;    

        //反转。将当前节点指向上一个节点,形成反转
		curr.next= prev;              
        //向后迭代。
        //迭代之后,新的上一个节点 pre,就是之前的"当前节点" curr
        //迭代之后,新的当前节点 curr,就是之前的"下一个节点" nextNode
		prev= curr;                    
		curr= nextNode;              
	}
    //最后prev会变成反转后的头节点,返回prev
     return prev;
}
相关推荐
坚持就完事了34 分钟前
滑动窗口算法
数据结构
有一个好名字1 小时前
力扣-奇偶链表
算法·leetcode·链表
im_AMBER1 小时前
Leetcode 103 反转链表 II
数据结构·c++·笔记·学习·算法·leetcode
Ka1Yan1 小时前
[链表] - 代码随想录 24. 两两交换链表中的节点
数据结构·链表
Python_Study20252 小时前
制造业企业如何构建高效数据采集系统:从挑战到实践
大数据·网络·数据结构·人工智能·架构
lixinnnn.2 小时前
优先级队列:最小函数值
数据结构·算法
Xの哲學2 小时前
Linux Worklet 深入剖析: 轻量级延迟执行机制
linux·服务器·网络·数据结构·算法
666HZ6662 小时前
数据结构2.1 线性表习题
c语言·数据结构·算法
yangminlei2 小时前
MySQL玩转数据可视化
数据结构·sql·oracle
CodeByV3 小时前
【算法题】链表
数据结构·算法