链表:反转链表

反转链表

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

迭代

比如,现有链表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;
}
相关推荐
我叫汪枫2 分钟前
C语言深度入门系列:第十一篇 - 动态内存管理与数据结构:程序世界的高效算法大师
c语言·数据结构·算法
啊?啊?9 分钟前
7 排序算法通关指南:从 O (n²)(选择 / 冒泡)到 O (nlogn)(快排 / 归并)+ 计数排序
数据结构·算法·排序算法
爱吃烤鸡翅的酸菜鱼1 小时前
【Redis】常用数据结构之List篇:从常用命令到典型使用场景
数据结构·redis·后端·缓存·list
会豪2 小时前
数据结构-栈/队列
数据结构
fangzelin53 小时前
算法-滑动窗口
数据结构·算法
iナナ5 小时前
Java优选算法——二分查找
数据结构·算法·leetcode
l1t5 小时前
利用美团龙猫添加xlsx的sheet.xml读取sharedStrings.xml中共享字符串输出到csv功能
xml·c语言·数据结构·人工智能·算法·解析器
lifallen7 小时前
揭秘KafkaStreams 线程缓存:NamedCache深度解析
数据结构·算法·缓存·kafka·apache
菜就多练,以前是以前,现在是现在7 小时前
Codeforces Round 1048 (Div. 2)
数据结构·c++·算法
失散138 小时前
分布式专题——9 Redis7底层数据结构解析
java·数据结构·redis·分布式·缓存·架构