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

算法——反转链表(leetcode206)

反转链表顾名思义就是将链表每个节点的next指向逆转将尾节点变为头结点将头结点变为尾节点从而得到反转链表。

对于这道题有两种方法第一种是双指针法,让指针pre指向节点为null指针cur指向头结点,通过temp临时变量存储cur的下一个节点的指针让cur.next=pre接着向后移动指针pre与指针cur也就是让pre=cur,cur=temp接着重复上述步骤遍历链表进行节点反转即可结束条件即为cur==null此时pre指向为头结点返回pre即可;下面有双指针和递归两种解法双指针代码思路清晰但递归方法看起来代码更简洁同时递归也比较难懂可以先写出双指针写法然后根据双指针思路写出递归方法接着可以去除一些冗余变量赋值操作即可;

方法一(双指针)

/**
 * Definition for singly-linked list.
 * public class ListNode {
 * int val;
 * ListNode next;
 * ListNode() {}
 * ListNode(int val) { this.val = val; }
 * ListNode(int val, ListNode next) { this.val = val; this.next = next; }
 * }
 */
class Solution {
    public ListNode reverseList(ListNode head) {
        ListNode temp=null;
        ListNode pre=null;
        ListNode cur=head;
        while(cur!=null){
            temp=cur.next;
            cur.next=pre;
            pre=cur;
            cur=temp;
        }
        return pre;
    }
}

方法二(递归)

/**
 * Definition for singly-linked list.
 * public class ListNode {
 *     int val;
 *     ListNode next;
 *     ListNode() {}
 *     ListNode(int val) { this.val = val; }
 *     ListNode(int val, ListNode next) { this.val = val; this.next = next; }
 * }
 */
class Solution {
    public ListNode reverseList(ListNode head) {
        return reverse(head,null);
    }
    public ListNode reverse(ListNode cur,ListNode pre){
        if(cur==null) return pre;
        else {
            ListNode temp=cur.next;
            cur.next=pre;
            return reverse(temp,cur);
        }
    }
}


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

相关文章:

  • ggplot2-scale_x_continuous()
  • STM32 使用 STM32CubeMX HAL库实现低功耗模式
  • 汽车资讯新篇章:Spring Boot技术启航
  • SpringBoot Data Redis连接Redis-Cluster集群
  • 理解 Python 中的 __getitem__ 方法:在自定义类中启用索引和切片操作
  • 游戏引擎学习第14天
  • 数据分析-48-时间序列变点检测之在线实时数据的CPD
  • Go语言24小时极速学习教程(三)常见标准库用法
  • 3-KSQL
  • 【C#设计模式(11)——外观模式(Facade Pattern)】
  • 大数据治理:构建数据价值链的关键环节
  • 安全见闻6-9
  • 机器学习day5-随机森林和线性代数1最小二乘法
  • SQL复杂数据类型处理
  • 解决虚拟机未被自动分配ip
  • 康威定律和数据中心网络
  • 【Python项目】基于深度学习的音乐推荐方法研究系统
  • transformers 操作篇
  • OpenHarmony-2.DeviceInfo适配
  • Docker compose部署elasticsearch(单机版)
  • 问题定位学习
  • 01-如何引导AI来帮助我们完善项目
  • Docker-01
  • Linux_shell脚本if语句详细教程
  • QT中的字符器类型
  • 基于springboot的景区网页设计与实现