当前位置: 首页 > article >正文

链表:反转链表

反转链表

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

迭代

比如,现有链表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;
}

http://www.kler.cn/a/234864.html

相关文章:

  • 设计模式之【观察者模式】
  • CSDN外链失效3:
  • 固定电话采用的是模拟信号还是数字信号?如果通话两端采用不同的信号会发生什么?
  • STM32单片机使用CAN协议进行通信
  • DB-GPT V0.6.3 版本更新:支持 SiliconCloud 模型、新增知识处理工作流等
  • 基于Spring Boot的智慧农业专家远程指导系统
  • Flask 入门7:使用 Flask-Moment 本地化日期和时间
  • [ai笔记1] 借着“ai春晚”开个场
  • 第三百一十五回
  • [ai笔记3] ai春晚观后感-谈谈ai与艺术
  • Linux---网络套接字
  • Linux(Ubuntu) 环境搭建:Nginx
  • 【MySQL基础】:深入探索DQL数据库查询语言的精髓(上)
  • 创建你的第一个Vue项目(小白专享版本)
  • 《Django+React前后端分离项目开发实战:爱计划》 02 安装Python和Django
  • Pytorch 复习总结 1
  • 【深度学习】pytorch 与 PyG 安装(pip安装)
  • Python无人弹药
  • 探索设计模式:原型模式深入解析
  • 第78讲 修改密码
  • 我的QQ编程学习群
  • [office] Excel表格中自动添加的超连接怎么取消? #媒体#其他#知识分享
  • 力扣:455. 分发饼干
  • qt中int和qint64的区别
  • Java:字符集、IO流 --黑马笔记
  • 房屋租赁系统的Java实战开发之旅