激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

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

服務(wù)器之家 - 編程語(yǔ)言 - JAVA教程 - Java實(shí)現(xiàn)表達(dá)式二叉樹(shù)

Java實(shí)現(xiàn)表達(dá)式二叉樹(shù)

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

這篇文章主要為大家詳細(xì)介紹了如何利用Java實(shí)現(xiàn)表達(dá)式二叉樹(shù),感興趣的小伙伴們可以參考一下

什么是二叉樹(shù),這里不再介紹,可以自行百度:二叉樹(shù)。在這里利用java實(shí)現(xiàn)“表達(dá)式二叉樹(shù)”。 

表達(dá)式二叉樹(shù)的定義 

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

Java實(shí)現(xiàn)表達(dá)式二叉樹(shù)

童靴們可能好奇這個(gè)到底是怎么構(gòu)建的?就拿45+23*56/2-5來(lái)說(shuō)吧。首先取出第一個(gè)數(shù)字45放在葉子節(jié)點(diǎn),遇到“+”后將其放到分支節(jié)點(diǎn),

Java實(shí)現(xiàn)表達(dá)式二叉樹(shù)

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

Java實(shí)現(xiàn)表達(dá)式二叉樹(shù)

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

Java實(shí)現(xiàn)表達(dá)式二叉樹(shù)

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

表達(dá)式二叉樹(shù)的構(gòu)建步驟
1.創(chuàng)建節(jié)點(diǎn)對(duì)象; 
2.辨析出操作符與數(shù)據(jù),存放在相應(yīng)的列表(隊(duì)列)中; 
3.取出前兩個(gè)數(shù)字和一個(gè)操作符,組成一個(gè)新的數(shù)字節(jié)點(diǎn); 
4.重復(fù)第3步,直到操作符取完為止; 
5.讓根節(jié)點(diǎn)等于最后一個(gè)節(jié)點(diǎn)。  

 表達(dá)式二叉樹(shù)的實(shí)現(xiàn)
 首先構(gòu)建節(jié)點(diǎn)對(duì)象類,包括數(shù)據(jù),左子樹(shù),右子樹(shù)和幾個(gè)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;
/**
 * 結(jié)點(diǎn)對(duì)象類
 * @author yuxiu
 *
 */
public class Node {
  // 數(shù)據(jù)
  private String data;
  // 左子樹(shù)
  private Node lchild;
  // 右子樹(shù)
  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;
  }
 
}

接著就是構(gòu)建表達(dá)式二叉樹(shù)了。 

 

?
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;
 
/**
 * 表達(dá)式二叉樹(shù)類
 * @author yuxiu
 *
 */
public class Formaluetree {
  private String s="";
  private Node root;   //根節(jié)點(diǎn)
  /**
   * 創(chuàng)建表達(dá)式二叉樹(shù)
   * @param str  表達(dá)式
   */
  public void creatTree(String str){
    //聲明一個(gè)數(shù)組列表,存放的操作符,加減乘除
    ArrayList<String> operList = new ArrayList<String>();
    //聲明一個(gè)數(shù)組列表,存放節(jié)點(diǎn)的數(shù)據(jù)
    ArrayList<Node> numList = new ArrayList<Node>();
    //第一,辨析出操作符與數(shù)據(jù),存放在相應(yīng)的列表中
    for(int i=0;i<str.length();i++){
      char ch = str.charAt(i);     //取出字符串的各個(gè)字符
      if(ch>='0'&&ch<='9'){
        s+=ch;
      }else{
        numList.add(new Node(s));
        s="";
        operList.add(ch+"");
        
      }
      
    }
    //把最后的數(shù)字加入到數(shù)字節(jié)點(diǎn)中
    numList.add(new Node(s));
    
    while(operList.size()>0){  //第三步,重復(fù)第二步,直到操作符取完為止
      //第二,取出前兩個(gè)數(shù)字和一個(gè)操作符,組成一個(gè)新的數(shù)字節(jié)點(diǎn)
      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);    //將新生的節(jié)點(diǎn)作為第一個(gè)節(jié)點(diǎn),同時(shí)以前index=0的節(jié)點(diǎn)變?yōu)閕ndex=1
      
    }
    //第四步,讓根節(jié)點(diǎn)等于最后一個(gè)節(jié)點(diǎn)
    root = numList.get(0);
            
  }
  /**
   * 輸出結(jié)點(diǎn)數(shù)據(jù)
   */
  public void output(){
      output(root);   //從根節(jié)點(diǎn)開(kāi)始遍歷
  }
  /**
   * 輸出結(jié)點(diǎn)數(shù)據(jù)
   * @param node
   */
  public void output(Node node){
    if(node.getLchild()!=null){    //如果是葉子節(jié)點(diǎn)就會(huì)終止
      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");//創(chuàng)建表達(dá)式的二叉樹(shù)
    tree.output();//輸出驗(yàn)證
 
  }
 
}

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

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持服務(wù)器之家。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 国产深夜福利视频在线播放 | 免费在线观看成年人视频 | 精品中文一区 | 免费在线观看成人av | 久久艹精品视频 | 视屏一区| 手机免费看一级片 | 精品国产一二区 | 久久久久久久久久久久久久av | 久久久久久久久久久久网站 | 欧美成人午夜 | 中文字幕在线视频日本 | 在线天堂中文字幕 | 娇喘在线| 97色在线观看免费视频 | 欧美 日韩 亚洲 中文 | 91经典视频 | www69xxxxx| 国产精品一区二区日韩 | 久久久久久久一区二区三区 | 亚洲欧美一区二区三区在线观看 | 一级免费在线视频 | 免费一级欧美在线观看视频 | 又黄又爽免费无遮挡在线观看 | 国产资源在线免费观看 | 香蕉在线播放 | 伊人yinren22综合网色 | 加勒比婷婷色综合久久 | 羞羞视频免费观看入口 | 日本韩国欧美一级片 | 久久福利在线 | 欧美一级黄色录像片 | chinese乱子伦xxxx国语对白 | 日本一区二区久久 | 亚洲导航深夜福利涩涩屋 | 毛片视频免费播放 | free台湾极品性hd | 日韩黄色片免费看 | 一区二区三区在线观看视频 | 黄视频网址 | 特级西西444www大精品视频免费看 |