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的情况,切记。

  • 相关阅读:
    magento删除local.xml后必须要页面安装
    magento后台无法打开
    ubuntu安装phpmyadmin
    数据结构有关于最优二叉树——最优哈夫曼树的建立过程和哈夫曼编码
    计算后缀表达式的过程(C#)
    mysql语句的相关操作整理
    mysql在控制台里出现中文问号问题
    Wampserver由橙变绿的解决过程
    重装win7系统的过程
    数据结构(C#):图的最短路径问题、(Dijkstra算法)
  • 原文地址:https://www.cnblogs.com/xiongmozhou/p/10162481.html
Copyright © 2011-2022 走看看