zoukankan      html  css  js  c++  java
  • java实现单链表反转(倒置)

    据说单链表反转问题面试中经常问,而链表这个东西相对于数组的确稍微难想象,因此今天纪录一下单链表反转的代码。

    1,先定义一个节点类。

    1 public class Node {
    2     int index;
    3     Node next;
    4 
    5     public Node(int index, Node next) {
    6       this.index = index;
    7       this.next = next;
    8     }
    9   }

    2,我一共写了三种方法

    (1)迭代法。先将下一节点纪录下来,然后让当前节点指向上一节点,再将当前节点纪录下来,再让下一节点变为当前节点

    public Node reverse(Node node) {
        Node prev = null;
        Node now = node;
        while (now != null) {
          Node next = now.next;
          now.next = prev;
          prev = now;
          now = next;
        }
    
        return prev;
      }

    (2)递归方法1。先找到最后一个节点,然后从最后一个开始反转,然后当前节点反转时其后面的节点已经进行反转了,不需要管。最后返回原来的最后一个节点

      

    public Node reverse2(Node node, Node prev) {
        if (node.next == null) {
          node.next = prev;
          return node;
        } else {
          Node re = reverse2(node.next, node);
          node.next = prev;
          return re;
        }
    }

    (3)递归方法2。先找到最后一个节点,然后从最后一个节点之前的那个节点的方法体中开始将下一个指向当前一个,然后当前节点反转时其后面的节点已经进行反转了,不需要管。最后返回原来的最后一个节点。

     
    public Node reverse3(Node node) {
        if(node.next==null)return node;
        Node next = node.next;
        node.next = null;
        Node re = reverse3(next);
        next.next = node;
        return re;
      }
     

    总结:迭代法思路很清晰,就是将当前节点和下一节点保存起来,然后将当前节点反转;递归法1是先找到最后一个节点进行反转,然后再反转之前的节点时就不用担心丢失以后的节点了,只需要关心本节点的反转;递归法2是同理,只是反转动作是从最后一个节点的前一个节点开始的。另外这几个方法都没有考虑首节点为null的情况,切记。

  • 相关阅读:
    常用的CSS命名规则 (web标准化设计)
    有哪些概率论和数理统计的深入教材可以推荐?
    CV2X国内现状分析
    隐私计算,新能源汽车“安全上路”的“救命稻草”?
    2022年中国车联网行业全景图谱
    2022年十大AI预测:气候独角兽涌现、中美竞争加剧
    OSEK/VDX介绍
    Adaptive Autosar
    基于我国商密算法的车联网5GV2X通信安全可信体系
    行研篇 | 汽车域控制器研究
  • 原文地址:https://www.cnblogs.com/xiongmozhou/p/10162481.html
Copyright © 2011-2022 走看看