欧美性猛交XXXX免费看蜜桃,成人网18免费韩国,亚洲国产成人精品区综合,欧美日韩一区二区三区高清不卡,亚洲综合一区二区精品久久

打開(kāi)APP
userphoto
未登錄

開(kāi)通VIP,暢享免費電子書(shū)等14項超值服

開(kāi)通VIP
表達式樹(shù)

用到了棧,并且遞歸實(shí)現了中序遍歷,后序遍歷,前序遍歷。

同時(shí)應該學(xué)會(huì )union的使用方法。


基礎知識:

一、表達式樹(shù)
    
    表達式樹(shù)的樹(shù)葉是操作數(operand),加常數或變量名字,而其他的結點(diǎn)為操作數(operator)。由于這里所有的操作都是二元的,因此這棵特定的樹(shù)正好是二叉樹(shù),雖然這是最簡(jiǎn)單的情況,但是結點(diǎn)還是有可能含有多于兩個(gè)的兒子,這里我們不討論。  


二、構造一棵表達式樹(shù)

    之前我們實(shí)現過(guò)一個(gè)中綴表達式求值的具體程序,在求值過(guò)程中需要用兩個(gè)棧,并且代碼并不簡(jiǎn)單。而這里你會(huì )看到,對于表達式樹(shù)的求值操作卻非常簡(jiǎn)單,甚至只需要兩條語(yǔ)句。因為這里大部分操作都是遞歸定義,二遞歸函數本身都是很簡(jiǎn)潔的,甚至比你想象的還要簡(jiǎn)單,甚至只需要兩條語(yǔ)句。因為這里大部分操作都是遞歸定義,二遞歸函數本身都是很簡(jiǎn)潔的,甚至比你想象的還要簡(jiǎn)單!就像樹(shù)的遍歷操作。三種遍歷分別是先序遍歷、中序遍歷與后序遍歷,正好對應表達式的三種形式:前綴型、中綴型與后綴型。其中為大家熟知的是中綴形式,如2+3*(5-4)。前綴型表達式又叫波蘭式(Polish Notation),后綴性表達式又叫逆波蘭式(Reverse Polish Notation)。他們最早于1920年波蘭數學(xué)家Jan Lukasiewicz發(fā)明,這兩種表示方式的最大特點(diǎn)是不需要括號來(lái)表明優(yōu)先級,他們經(jīng)常用于計算機科學(xué),特別是編譯器設計方面。

    下面給出一種算法來(lái)把后綴表達式轉變成表達式樹(shù)。我們一次一個(gè)符號地讀入表達式。如果符號是操作數,那么就建立一個(gè)單結點(diǎn)樹(shù)并將它推入棧中。如果符號是操作符,那么就從棧中彈出兩棵樹(shù)T1和T2(T1先彈出)并形成一棵新的樹(shù),該樹(shù)的根就是操作符,它的左、右兒子分別是T2和T1。然后將指向這顆樹(shù)的指針壓入棧中。

    下面來(lái)看一個(gè)例子。設輸入為ab+cde+**

前兩個(gè)符號是操作數,因此創(chuàng )建兩棵單結點(diǎn)樹(shù)并將指向它們的指針壓入棧中。
接著(zhù),"+"被讀入,因此指向兩棵樹(shù)的指針被彈出,形成一棵新的樹(shù),并將指向它的指針壓入棧中。

然后,c,d和e被讀入,在單個(gè)結點(diǎn)樹(shù)創(chuàng )建后,指向對應的樹(shù)的指針被壓入棧中。
 
 
接下來(lái)讀入"+"號,因此兩棵樹(shù)合并。
 
 
繼續進(jìn)行,讀入"*"號,因此,彈出兩棵樹(shù)的指針合并形成一棵新的樹(shù),"*"號是它的根。
最后,讀入一個(gè)符號,兩棵樹(shù)合并,而指向最后的樹(shù)的指針被留在棧中。
 


  1. #include <stdio.h>  
  2. #include <stdlib.h>  
  3.   
  4. #define MAX 100  
  5.   
  6. /* 樹(shù)結點(diǎn)的設計 */  
  7. typedef struct node  
  8. {  
  9.     /* 數字和運算符 */  
  10.     union  
  11.     {  
  12.         char operator;  
  13.         int data;  
  14.     };  
  15.   
  16.     struct node *lchild;  
  17.     struct node *rchild;  
  18. }TreeNode;  
  19.   
  20. /* 樹(shù)棧 */  
  21. typedef struct Tree_Stack  
  22. {  
  23.     TreeNode *buf[MAX];  
  24.     int n;  
  25. }TreeStack;  
  26.   
  27. /* 創(chuàng )建空棧 */  
  28. TreeStack *create_empty_stack()  
  29. {  
  30.     TreeStack *pstack;  
  31.   
  32.     pstack = (TreeStack *)malloc(sizeof(TreeStack));  
  33.     pstack->n = -1;  
  34.   
  35.     return pstack;  
  36. }  
  37.   
  38. /* 入棧 */  
  39. int push_stack(TreeStack *p, TreeNode *data)  
  40. {  
  41.     p->n++;  
  42.     p->buf[p->n] = data;  
  43.   
  44.     return 0;  
  45. }  
  46.   
  47. /* 出棧 */  
  48. TreeNode *pop_stack(TreeStack *p)  
  49. {  
  50.     TreeNode *data;  
  51.   
  52.     data = p->buf[p->n];  
  53.     p->n --;  
  54.   
  55.     return data;  
  56. }  
  57.   
  58. /* 判斷???nbsp;*/  
  59. int is_empty_stack(TreeStack *p)  
  60. {  
  61.     if(p->n == -1)  
  62.         return 1;  
  63.     else  
  64.         return 0;  
  65. }  
  66.   
  67. /* 創(chuàng )建后綴表達式樹(shù) */  
  68. TreeNode *create_express_tree(char *str, TreeStack *p)  
  69. {  
  70.     int i = 0;  
  71.     TreeNode *current;  
  72.     TreeNode *left, *right;  
  73.   
  74.     while(str[i])  
  75.     {  
  76.         if(str[i] >= '0' && str[i] <= '9')  
  77.         {  
  78.             current = (TreeNode *)malloc(sizeof(TreeNode));  
  79.             current->data = str[i] - '0';  
  80.             current->lchild = NULL;  
  81.             current->rchild = NULL;  
  82.             push_stack(p, current);  
  83.         }  
  84.         else  
  85.         {  
  86.             current = (TreeNode *)malloc(sizeof(TreeNode));  
  87.             current->operator = str[i];  
  88.             right = pop_stack(p);  
  89.             left = pop_stack(p);  
  90.             current->lchild = left;  
  91.             current->rchild = right;  
  92.             push_stack(p, current);  
  93.         }  
  94.         i++;  
  95.     }  
  96.     return p->buf[p->n];  
  97. }  
  98.   
  99. /* 打印結點(diǎn) */  
  100. void print_node(TreeNode *p)  
  101. {  
  102.     if(p->lchild == NULL && p->rchild == NULL)  
  103.         printf("%d ", p->data);  
  104.     else  
  105.         printf("%c ", p->operator);  
  106. }  
  107.   
  108. /* 訪(fǎng)問(wèn)結點(diǎn) */  
  109. int visit_node(TreeNode *p)  
  110. {  
  111.     print_node(p);  
  112.   
  113.     return 0;  
  114. }  
  115.   
  116. /* 樹(shù)的后序遍歷 */  
  117. void PostOrder(TreeNode *p)  
  118. {  
  119.     if(p != NULL)  
  120.     {  
  121.         PostOrder(p->lchild);  
  122.         PostOrder(p->rchild);  
  123.         visit_node(p);  
  124.     }  
  125. }  
  126.   
  127. /* 樹(shù)的中序遍歷 */  
  128. void InOrder(TreeNode *p)  
  129. {  
  130.     if(p != NULL)  
  131.     {  
  132.         InOrder(p->lchild);  
  133.         visit_node(p);  
  134.         InOrder(p->rchild);  
  135.     }  
  136. }  
  137.   
  138. /* 樹(shù)的前序遍歷 */  
  139. void PreOrder(TreeNode *p)  
  140. {  
  141.     if(p != NULL)  
  142.     {  
  143.         visit_node(p);  
  144.         PreOrder(p->lchild);  
  145.         PreOrder(p->rchild);  
  146.     }  
  147. }  
  148.   
  149. int main()  
  150. {  
  151.     TreeNode *thead;  
  152.     TreeStack *pstack;  
  153.     int i = 0;  
  154.     char buf[100];  
  155.   
  156.     scanf("%s", buf);  
  157.   
  158.     pstack = create_empty_stack();  
  159.     thead = create_express_tree(buf, pstack);  
  160.   
  161.     printf("PostOrder:  ");  
  162.     PostOrder(thead);  
  163.     printf("\n");  
  164.   
  165.     printf("InOrder:  ");  
  166.     InOrder(thead);  
  167.     printf("\n");  
  168.   
  169.     printf("PreOrder:  ");  
  170.     PreOrder(thead);  
  171.     printf("\n");  
  172.   
  173.     return 0;  
  174. }  

測試結果如下:


本站僅提供存儲服務(wù),所有內容均由用戶(hù)發(fā)布,如發(fā)現有害或侵權內容,請點(diǎn)擊舉報。
打開(kāi)APP,閱讀全文并永久保存 查看更多類(lèi)似文章
猜你喜歡
類(lèi)似文章
二叉樹(shù)和樹(shù)
二叉樹(shù)遍歷非遞歸算法
二叉樹(shù)的深度優(yōu)先遍歷、廣度優(yōu)先遍歷和非遞歸遍歷
《算法導論》讀書(shū)筆記之第10章 基本數據結構之二叉樹(shù)
更簡(jiǎn)單的非遞歸遍歷二叉樹(shù)的方法
【漫畫(huà)】什么是二叉樹(shù)?
更多類(lèi)似文章 >>
生活服務(wù)
分享 收藏 導長(cháng)圖 關(guān)注 下載文章
綁定賬號成功
后續可登錄賬號暢享VIP特權!
如果VIP功能使用有故障,
可點(diǎn)擊這里聯(lián)系客服!

聯(lián)系客服

欧美性猛交XXXX免费看蜜桃,成人网18免费韩国,亚洲国产成人精品区综合,欧美日韩一区二区三区高清不卡,亚洲综合一区二区精品久久