一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|JAVA教程|ASP教程|

服務器之家 - 編程語言 - JAVA教程 - Java實現表達式二叉樹

Java實現表達式二叉樹

2020-06-03 11:35my筆觸 JAVA教程

這篇文章主要為大家詳細介紹了如何利用Java實現表達式二叉樹,感興趣的小伙伴們可以參考一下

什么是二叉樹,這里不再介紹,可以自行百度:二叉樹。在這里利用java實現“表達式二叉樹”。 

表達式二叉樹的定義 

第一步先要搞懂表達式二叉樹是個什么東東?舉個栗子,表達式:(a+b×(c-d))-e/f。將數字放在葉子節點,將操作符放在分支節點,就構成了一個二叉樹,由于存儲的是一個表達式,稱之為“表達式二叉樹”。

Java實現表達式二叉樹

童靴們可能好奇這個到底是怎么構建的?就拿45+23*56/2-5來說吧。首先取出第一個數字45放在葉子節點,遇到“+”后將其放到分支節點,

Java實現表達式二叉樹

然后將“23”、“*”、“56”、“/”、“2”依次放入,

Java實現表達式二叉樹

最后放入“-”、“5”,

Java實現表達式二叉樹

大致就是這樣。(這些圖我自己畫的,比較丑,大家看看就好(⊙﹏⊙))

表達式二叉樹的構建步驟
1.創建節點對象; 
2.辨析出操作符與數據,存放在相應的列表(隊列)中; 
3.取出前兩個數字和一個操作符,組成一個新的數字節點; 
4.重復第3步,直到操作符取完為止; 
5.讓根節點等于最后一個節點。  

 表達式二叉樹的實現
 首先構建節點對象類,包括數據,左子樹,右子樹和幾個set、get方法。 

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
package tets0714;
/**
 * 結點對象類
 * @author yuxiu
 *
 */
public class Node {
  // 數據
  private String data;
  // 左子樹
  private Node lchild;
  // 右子樹
  private Node rchild;
 
  Node() {
  }
 
  Node(String data) {
    this.data = data;
  }
 
  Node(String data, Node lchild, Node rchild) {
    super();
    this.data = data;
    this.lchild = lchild;
    this.rchild = rchild;
 
  }
  public String getData() {
    return data;
  }
  public Node getLchild() {
    return lchild;
  }
  public Node getRchild() {
    return rchild;
  }
 
}

接著就是構建表達式二叉樹了。 

 

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
package tets0714;
 
import java.util.ArrayList;
 
/**
 * 表達式二叉樹類
 * @author yuxiu
 *
 */
public class Formaluetree {
  private String s="";
  private Node root;   //根節點
  /**
   * 創建表達式二叉樹
   * @param str  表達式
   */
  public void creatTree(String str){
    //聲明一個數組列表,存放的操作符,加減乘除
    ArrayList<String> operList = new ArrayList<String>();
    //聲明一個數組列表,存放節點的數據
    ArrayList<Node> numList = new ArrayList<Node>();
    //第一,辨析出操作符與數據,存放在相應的列表中
    for(int i=0;i<str.length();i++){
      char ch = str.charAt(i);     //取出字符串的各個字符
      if(ch>='0'&&ch<='9'){
        s+=ch;
      }else{
        numList.add(new Node(s));
        s="";
        operList.add(ch+"");
        
      }
      
    }
    //把最后的數字加入到數字節點中
    numList.add(new Node(s));
    
    while(operList.size()>0){  //第三步,重復第二步,直到操作符取完為止
      //第二,取出前兩個數字和一個操作符,組成一個新的數字節點
      Node left = numList.remove(0);
      Node right = numList.remove(0);
      String oper = operList.remove(0);
      
      Node node = new Node(oper,left,right);
      numList.add(0,node);    //將新生的節點作為第一個節點,同時以前index=0的節點變為index=1
      
    }
    //第四步,讓根節點等于最后一個節點
    root = numList.get(0);
            
  }
  /**
   * 輸出結點數據
   */
  public void output(){
      output(root);   //從根節點開始遍歷
  }
  /**
   * 輸出結點數據
   * @param node
   */
  public void output(Node node){
    if(node.getLchild()!=null){    //如果是葉子節點就會終止
      output(node.getLchild());
    }
    System.out.print(node.getData());   //遍歷包括先序遍歷(根左右)、中序遍歷(左根右)、后序遍歷(左右根)
    if(node.getRchild()!=null){
      output(node.getRchild());
    }
    
  }
  
 
  public static void main(String[] args) {
    Formaluetree tree = new Formaluetree();
    tree.creatTree("45+23*56/2-5");//創建表達式的二叉樹
    tree.output();//輸出驗證
 
  }
 
}

最后在控制臺可以輸出“45+23*56/2-5”,OK了。這里使用的中序遍歷,小伙伴們可以試試采用先序遍歷、后序遍歷是什么效果。至于遍歷,我們后面再講。

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

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 天堂在线中文无弹窗全文阅读 | 亚洲精品在线免费观看视频 | 99久久精品免费精品国产 | 青草青草伊人精品视频 | 久久电影午夜 | 久久成人伊人欧洲精品AV | 操美女b| 色老板最新网站视频地址 | 99视频久久精品久久 | 亚洲人成网站在线观看妞妞网 | 美国雪白人妖sarina | 五月天精品视频播放在线观看 | 91噜噜噜在线观看 | 国产精品视频免费观看 | 轻轻色在线视频中文字幕 | 亚洲国产精品久久久久久 | 成人性用品 | 毛片网在线观看 | 国产成人在线影院 | 美女尿口羞羞视频 | 大乳女子一级毛片 | 暖暖日本在线观看免费 | 麻豆在线观看 | chinese国产老太性 | 美女自插 | 久久免费观看视频 | 日本福利网 | 国产大片网站 | 操小女人 | 勾搭已婚高h | japan孕妇孕交freehd | 236宅宅2021最新理论 | 欧美坐爱 | 歪歪视频在线播放无遮挡 | 国内精品久久久久影院男同志 | 91porny新九色在线 | 大陆黄色片 | 特黄特色大片免费高清视频 | 免费视频观看 | 四虎国产欧美成人影院 | 精品无人区一区二区三区 |