中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

JAVA實現雙向鏈表的增刪功能的方法

發布時間:2020-10-11 10:14:17 來源:腳本之家 閱讀:345 作者:song.yan 欄目:編程語言

JAVA實現雙向鏈表的增刪功能,完整代碼

package linked;
class LinkedTable{  
}
public class LinkedTableTest {
   //構造單鏈表
  static Node node1 = new Node("name1");
  static Node node2 = new Node("name2");
  static Node node3 = new Node("name3");
  static Node node4 = new Node("name4");
  static Node node5 = new Node("name5");
  public static void main(String[] args)
  {
    //設置指針
    setPoint();
    
    //循環遍歷
    System.out.println("*******初始鏈表*******");
    out(node1,node5);
    System.out.println();
    
    //插入節點在node2的后面
    addNode(node2,node3);
    
    // 循環遍歷
    System.out.println("*******插入node2.5*******");
    out(node1, node5);
    System.out.println();
        
    //刪除節點
    node2.setNextNode(node3);
    node3.setNextNodeF(node2);
    
    // 循環遍歷
    System.out.println("*******刪除node2.5*******");
    out(node1, node5);
    System.out.println();
    
  }
  
  //設置指針
  public static void setPoint()
  {
    //設置正向指針
    node1.setNextNode(node2);
    node2.setNextNode(node3);
    node3.setNextNode(node4);
    node4.setNextNode(node5);
    //設置反向指針
    node5.setNextNodeF(node4);
    node4.setNextNodeF(node3);
    node3.setNextNodeF(node2);
    node2.setNextNodeF(node1);
  }
  
  //循環遍歷單鏈表
  public static void outLinked(Node startNode){
    Node node= new Node();
    node.setNextNode(startNode);
    do
    {
      node=node.getNextNode();
      System.out.print(node.getName()+"----");  
    }while(node.getNextNode()!=null);
  }
  
  //反向循環遍歷單鏈表
  public static void outLinkedF(Node endNode){
    Node node= new Node();
    node.setNextNodeF(endNode);
    do
    {
      node=node.getNextNodeF();
      System.out.print(node.getName()+"----");  
    }while(node.getNextNodeF()!=null);
  }
  
  //循環遍歷
  public static void out(Node startNode,Node endNode)
  {
    outLinked(startNode);
    System.out.println();
    outLinkedF(endNode);    
  }
  
  //插入節點
  public static void addNode(Node preNode,Node nextNode)
  {
    Node node_add = new Node("name2.5");
    node_add.setNextNode(preNode.getNextNode());
    preNode.setNextNode(node_add);    
    node_add.setNextNodeF(nextNode.getNextNodeF());
    nextNode.setNextNodeF(node_add);
  }  
}

class Node {
  private String name;
  private Node nextNode;
  private Node nextNodeF;
  public void setName(String name)
  {
    this.name=name;
  }
  public void setNextNode(Node nextNode)
  {
    this.nextNode=nextNode;
  }
  public void setNextNodeF(Node nextNodeF)
  {
    this.nextNodeF=nextNodeF;
  }
  public String getName()
  {
    return this.name;
  }
  public Node getNextNode()
  {
    return this.nextNode;
  }
  public Node getNextNodeF()
  {
    return this.nextNodeF;
  }
  public Node(String name)
  {
    this.name=name;
    this.nextNode=null;
  }
  public Node( )
  {    
  }  
}

1,構造node節點,需要兩個指針,一個正向存儲下一個元素的位置,一個反向存儲下一個元素的位置

JAVA實現雙向鏈表的增刪功能的方法

參數說明:

  name:用于存儲node自身的信息

  nextNode:用于存儲正向指針

  nextNodeF:用于存儲反向指針

class Node {
  private String name;
  private Node nextNode;
  private Node nextNodeF;
  public void setName(String name)
  {
    this.name=name;
  }
  public void setNextNode(Node nextNode)
  {
    this.nextNode=nextNode;
  }
  public void setNextNodeF(Node nextNodeF)
  {
    this.nextNodeF=nextNodeF;
  }
  public String getName()
  {
    return this.name;
  }
  public Node getNextNode()
  {
    return this.nextNode;
  }
  public Node getNextNodeF()
  {
    return this.nextNodeF;
  }
  public Node(String name)
  {
    this.name=name;
    this.nextNode=null;
  }
  public Node( )
  {    
  }  
}

2,創建節點,設置指針連接節點

正向指針:指向下一個節點

反向節點:指向上一個節點

//構造單鏈表
  static Node node1 = new Node("name1");
  static Node node2 = new Node("name2");
  static Node node3 = new Node("name3");
  static Node node4 = new Node("name4");
  static Node node5 = new Node("name5");
public static void setPoint()
  {
    //設置正向指針
    node1.setNextNode(node2);
    node2.setNextNode(node3);
    node3.setNextNode(node4);
    node4.setNextNode(node5);
    //設置反向指針
    node5.setNextNodeF(node4);
    node4.setNextNodeF(node3);
    node3.setNextNodeF(node2);
    node2.setNextNodeF(node1);
  }

3,將鏈表循環遍歷輸出

public static void outLinked(Node startNode){
    Node node= new Node();
    node.setNextNode(startNode);
    do
    {
      node=node.getNextNode();
      System.out.print(node.getName()+"----");  
    }while(node.getNextNode()!=null);
  }

  public static void outLinkedF(Node endNode){
    Node node= new Node();
    node.setNextNodeF(endNode);
    do
    {
      node=node.getNextNodeF();
      System.out.print(node.getName()+"----");  
    }while(node.getNextNodeF()!=null);
  }

4,添加節點

  public static void addNode(Node preNode,Node nextNode)
  {
    Node node_add = new Node("name2.5");
    node_add.setNextNode(preNode.getNextNode());
    preNode.setNextNode(node_add);
    
    node_add.setNextNodeF(nextNode.getNextNodeF());
    nextNode.setNextNodeF(node_add);
  }

5,刪除節點

node2.setNextNode(node3);
node3.setNextNodeF(node2);

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

淅川县| 阿巴嘎旗| 尼勒克县| 湟源县| 台中市| 古交市| 固始县| 利辛县| 高密市| 海淀区| 达日县| 广东省| 偏关县| 山阳县| 昌邑市| 大宁县| 无棣县| 时尚| 南乐县| 宁安市| 巧家县| 乌兰浩特市| 汾西县| 资兴市| 赤水市| 元阳县| 阿瓦提县| 京山县| 高密市| 南岸区| 上林县| 雷州市| 成都市| 黔南| 长治市| 鄱阳县| 大安市| 年辖:市辖区| 淳安县| 海宁市| 浙江省|