反转链表(算法)

复制代码
 1 public ListNode reLinked(ListNode head){
 2     ListNode currentHead = head;//当前节点
 3     ListNode newHead = null;//当前节点前一节点
 4     if(currentHead==null || currentHead.next==null){
 5         return currentHead;      
 6     }
 7     while(currentHead!=null){
 8          ListNode nextNode = currentHead.next;//当前节点后一节点
 9          currentHead.next = newHead;
10          newHead = currentHead;    
11          currentHead = nextNode;
12     }
13     return newHead;      
14 }    
复制代码

代码分析

反转链表的关键在于给定两个指针(当前指针,当前指针上一个指针)

8行:定义一个节点临时存储当前节点的后一节点

9行:将当前节点的前一节点赋给当前节点(反转)

10行:当前节点前一节点前移到当前节点

11行:当前节点后移到下一节点(进行下一轮反转)

       

    

       

       

 

posted @   Q子  阅读(62)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 零经验选手,Compose 一天开发一款小游戏!
· 通过 API 将Deepseek响应流式内容输出到前端
· 因为Apifox不支持离线,我果断选择了Apipost!
点击右上角即可分享
微信分享提示