博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
剑指offer例题——反转链表
阅读量:6290 次
发布时间:2019-06-22

本文共 1226 字,大约阅读时间需要 4 分钟。

题目描述

输入一个链表,反转链表,输出新链表的表头

程序编写

将链表反转

1 public class Solution { 2     public ListNode ReverseList(ListNode head) { 3         4         if(head==null) 5             return null; 6         //head为当前节点,如果当前节点为空的话,那就什么也不做,直接返回null; 7         ListNode pre = null; 8         ListNode next = null; 9         //当前节点是head,pre为当前节点的前一节点,next为当前节点的下一节点10         //需要pre和next的目的是让当前节点从pre->head->next1->next2变成pre<-head next1->next211         //即pre让节点可以反转所指方向,但反转之后如果不用next节点保存next1节点的话,此单链表就此断开了12         //所以需要用到pre和next两个节点13         //1->2->3->4->514         //1<-2<-3 4->515         while(head!=null){16             //做循环,如果当前节点不为空的话,始终执行此循环,此循环的目的就是让当前节点从指向next到指向pre17             //如此就可以做到反转链表的效果18             //先用next保存head的下一个节点的信息,保证单链表不会因为失去head节点的原next节点而就此断裂19             next = head.next;20             //保存完next,就可以让head从指向next变成指向pre了,代码如下21             head.next = pre;22             //head指向pre后,就继续依次反转下一个节点23             //让pre,head,next依次向后移动一个节点,继续下一次的指针反转24             pre = head;25             head = next;26         }27         //如果head为null的时候,pre就为最后一个节点了,但是链表已经反转完毕,pre就是反转后链表的第一个节点28         //直接输出pre就是我们想要得到的反转后的链表29         return pre;30     }31 }

 

转载于:https://www.cnblogs.com/10081-AA/p/10639136.html

你可能感兴趣的文章
2(2).选择排序_冒泡(双向循环链表)
查看>>
MySQL 索引 BST树、B树、B+树、B*树
查看>>
微信支付
查看>>
CodeBlocks中的OpenGL
查看>>
短址(short URL)
查看>>
第十三章 RememberMe——《跟我学Shiro》
查看>>
mysql 时间函数 时间戳转为日期
查看>>
索引失效 ORA-01502
查看>>
Oracle取月份,不带前面的0
查看>>
Linux Network Device Name issue
查看>>
IP地址的划分实例解答
查看>>
如何查看Linux命令源码
查看>>
运维基础命令
查看>>
入门到进阶React
查看>>
SVN 命令笔记
查看>>
检验手机号码
查看>>
重叠(Overlapped)IO模型
查看>>
Git使用教程
查看>>
使用shell脚本自动监控后台进程,并能自动重启
查看>>
Flex&Bison手册
查看>>