表達式建樹

 //用數組實現樹
1
#include<iostream> 2 #include<ctype.h> 3 #include<cstring> 4 #define N 10000 5 #define optd 1 6 #define optr 2 7 using namespace std; 8 int treeL[N], treeR[N]; 9 class node 10 { 11 public: 12 int flag;//區分當前節點是操作符還是操作數 13 double k; 14 char ch; 15 }; 16 17 node opt[N]; 18 int nodeN; 19 char formula[1000]; 20 21 int buildTree(int ld, int rd) 22 { 23 int i; 24 for(i=ld; i<rd; ++i) 25 if(!isdigit(formula[i])) 26 break; 27 if(i>=rd)//最后全部為數字的時候 28 { 29 ++nodeN; 30 opt[nodeN].flag=optd; 31 sscanf(formula+ld, "%lf", &opt[nodeN].k); 32 treeL[nodeN]=treeR[nodeN]=0;//末端節點沒有左右孩子 33 return nodeN;//返回當前所建節點編號 34 } 35 int pAS=-1, pMD=-1;//分別表示加減號, 乘除號所在的位置 36 int paren=0;//記錄左括弧相對于右括弧出現的數目 37 for(i=ld; i<rd; ++i) 38 { 39 switch(formula[i]) 40 { 41 case '(': ++paren; break; 42 case ')': --paren; break; 43 44 //最后計算的運算符一定是在括弧的外邊,不會包含在括弧里邊 45 case '+': 46 case '-': 47 if(paren==0) pAS=i; 48 break; 49 case '*': 50 case '/': 51 if(paren==0) pMD=i; 52 break; 53 } 54 } 55 if(pAS<0) pAS=pMD; 56 if(pAS<0) //說明沒有找到括弧外邊的運算符,則脫掉一對括弧重新尋找 57 return buildTree(ld+1, rd-1); 58 int u=++nodeN; 59 opt[u].flag=optr;//表示存儲操作符 60 opt[u].ch=formula[pAS]; 61 treeL[u]=buildTree(ld, pAS); 62 treeR[u]=buildTree(pAS+1, rd); 63 return u; 64 } 65 66 void printTree(int cur)//中序輸出表達式樹 67 { 68 if(cur)//非末端節點 69 { 70 printTree(treeL[cur]); 71 if(opt[cur].flag==optd) 72 cout<<opt[cur].k<<" "; 73 else 74 cout<<opt[cur].ch<<" "; 75 printTree(treeR[cur]); 76 } 77 } 78 79 int main() 80 { 81 while(cin>>formula) 82 { 83 buildTree(0, strlen(formula)); 84 printTree(1); 85 } 86 return 0; 87 }
 //用鏈表實現樹
1
#include<iostream> 2 #include<ctype.h> 3 #include<cstring> 4 #define N 10000 5 #define optd 1 6 #define optr 2 7 using namespace std; 8 9 class node 10 { 11 public: 12 node *lchild, *rchild; 13 int flag;//區分當前節點是操作符還是操作數 14 double k; 15 char ch; 16 }; 17 18 char formula[1000]; 19 20 void buildTree(node* &T, int ld, int rd) 21 { 22 int i; 23 for(i=ld; i<rd; ++i) 24 if(!isdigit(formula[i])) 25 break; 26 if(i>=rd)//最后全部為數字的時候 27 { 28 T=new node(); 29 T->flag=optd; 30 sscanf(formula+ld, "%lf", &T->k); 31 return ; 32 } 33 int pAS=-1, pMD=-1;//分別表示加減號, 乘除號所在的位置 34 int paren=0;//記錄左括弧相對于右括弧出現的數目 35 for(i=ld; i<rd; ++i) 36 { 37 switch(formula[i]) 38 { 39 case '(': ++paren; break; 40 case ')': --paren; break; 41 42 //最后計算的運算符一定是在括弧的外邊,不會包含在括弧里邊 43 case '+': 44 case '-': 45 if(paren==0) pAS=i; 46 break; 47 case '*': 48 case '/': 49 if(paren==0) pMD=i; 50 break; 51 } 52 } 53 if(pAS<0) pAS=pMD; 54 if(pAS<0) //說明沒有找到括弧外邊的運算符,則脫掉一對括弧重新尋找 55 return buildTree(T, ld+1, rd-1); 56 T=new node(); 57 T->flag=optr;//表示存儲操作符 58 T->ch=formula[pAS]; 59 buildTree(T->lchild, ld, pAS); 60 buildTree(T->rchild, pAS+1, rd); 61 } 62 63 void printTree(node *T)//中序輸出表達式樹 64 { 65 if(T)//非末端節點 66 { 67 printTree(T->lchild); 68 if(T->flag==optd) 69 cout<<T->k<<" "; 70 else 71 cout<<T->ch<<" "; 72 printTree(T->rchild); 73 } 74 } 75 76 int main() 77 { 78 while(cin>>formula) 79 { 80 node *T=NULL; 81 buildTree(T, 0, strlen(formula)); 82 printTree(T); 83 } 84 return 0; 85 }

?

?

轉載于:https://www.cnblogs.com/hujunzheng/p/3786399.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/531987.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/531987.shtml
英文地址,請注明出處:http://en.pswp.cn/news/531987.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

python label標簽的作用_label標簽的作用是什么?

label標簽的作用是為鼠標用戶改進了可用性&#xff0c;當用戶點擊【】標簽中的文本時&#xff0c;瀏覽器就會自動將焦點轉到和該標簽相關聯的控件上。label標簽的作用&#xff1a;一、標簽定義及用法在html中&#xff0c;標簽通常和標簽一起使用&#xff0c;標簽為input元素定義…

java異常自定義返回信息,Spring Boot 如何自定義返回錯誤碼錯誤信息

說明在實際的開發過程中,很多時候要定義符合自己業務的錯誤碼和錯誤信息&#xff0c;而不是統一的而不是統一的下面這種格式返回到調用端INTERNAL_SERVER_ERROR(500, "Internal Server Error"),下面我們來看看如何將我們自定義的錯誤碼和錯誤信息返回到調用端。1 自定…

文件管理系統_Python學習第170節--Linux文件管理系統實際操作和具體介紹

【每天幾分鐘&#xff0c;從零入門python編程的世界&#xff01;】上節我們簡單了解了Linux文件管理系統&#xff0c;現在我們學習它的實際操作。首先我們解釋下~和/的區別。~之前我們介紹過&#xff0c;我們說~是Linux系統的根目錄&#xff0c;其實這個說法是不準確的&#xf…

redis 計數器 java_Redis 的 8 大應用場景!

之前講過Redis的介紹&#xff0c;及使用Redis帶來的優勢&#xff0c;這章整理了一下Redis的應用場景&#xff0c;也是非常重要的&#xff0c;學不學得好&#xff0c;能正常落地是關鍵。下面一一來分析下Redis的應用場景都有哪些。1、緩存緩存現在幾乎是所有中大型網站都在用的必…

sql中in與php數組,格式化SQL“IN”子句的PHP數組

我正在嘗試在數據庫中查詢“product_id”包含在產品ID數組中的記錄.該數組是多選輸入(< select>)的結果,如下所示&#xff1a;$clients Array ([0] > 80000016-1302638679[1] > 8000003B-1329924004)我想將該數組傳遞給sql語句的“IN”子句,例如&#xff1a;$sql …

匯編漢諾塔

1 .3862 .model flat3 .stack 40964 include io.h5 ExitProcess proto near32 stdcall, ExitCode:dword6 cr equ 0dh7 lf equ 0ah8 .data9 string1 byte "請輸入漢諾塔數&#xff1a;", cr, lf 10 strNum byte 10 dup(?) 11 result byte 10 dup( ) 12 byte c…

oracle精度說明符1~38_Oracle 錯誤代碼總結及解決方案

ORA-00001&#xff1a;違反唯一約束條件(主鍵錯誤)ORA-00028&#xff1a;無法連接數據庫進程ORA-00900&#xff1a;無效sql語句ORA-00904&#xff1a;字段名寫錯或是建表時最后一個字段有逗號ORA-00907&#xff1a;缺少右括號ORA-00911&#xff1a;無效字符ORA-00917&#xff1…

opencv為matlab,OpenCV與matlab部分函數的對應關系(轉)

2、matlab中的zeros函數相當于OpenCV中的cvSetZero函數。3、matlab中的兩矩陣點乘 .*相當于OpenCV中的cvMul函數。4、matlab中的兩矩陣點除 ./相當于OpenCV中的cvDiv函數。5、matlab中的兩矩陣相加 相當于OpenCV中的cvAdd函數。6、matlab中的兩矩陣相減 -相當于OpenCV中的cvSub…

預測分析算法的設計與實現_基于LD(編輯距離算法)的單詞速記數據庫分析設計與實現...

2020-21-1學期《最新數據庫管理系統》結課作業展示。作者&#xff1a;牟倫利 褚四浩 陳思琴 曹鵬飛(電商11802)分工陳思琴&#xff1a;系統需求分析 、系統相關算法分析和ER圖曹鵬飛&#xff1a;系統數據字典 、業務流程圖、數據流程圖和PPT制作牟倫利&#xff1a;存儲過程、觸…

參考文獻要不要首行縮進_參考文獻格式要求(2015-2016-2)

1參考文獻統一使用下列格式一、參考文獻構成參考文獻分為兩個部分&#xff1a;正文部分的夾注和文后參考文獻處的參考文獻條目。1.正文部分的夾注(作者的姓頁碼)正文引用了他人的觀點后&#xff0c;在后面緊靠引用處給出夾注。例如&#xff1a;The contemporary text linguisti…

c++與java中子類中調用父類成員的方法

1 java中&#xff1a;2 import java.util.Scanner;3 public class ClassTest{4 public static void main(String args[]){5 child chnew child(2);6 parent pch;7 p.print();8 //p.print2();//調用錯誤&#xff0c;父類中沒有改成員方法&#xff0c…

華為暢享max有沒有人臉識別_華為暢享7s有人臉識別嗎 讓我來告訴你

現在大家使用手機的頻率越來越頻繁&#xff0c;手機也為我們提供了許多的便利&#xff0c;今天小編也來說一下這個華為暢享7s有人臉識別嗎 讓我來告訴你相關的文章&#xff0c;這個操作其實不復雜&#xff0c;接下來就給大家介紹一下華為暢享7s有人臉識別嗎 讓我來告訴你&#…

matlab knnsearchidx,matlab查找最臨近搜索knnsearch

[Idx,D] knnsearch(___) additionally returns the matrix D, using any of the input arguments in the previous syntaxes. D contains the distances between each observation in Y and the corresponding closest observations in X.使用先前語法中的任何輸入參數返回矩陣…

php導出excel數據代碼,phpspreadsheet導出數據到Excel的方法介紹(代碼示例)

本篇文章給大家帶來的內容是關于phpspreadsheet導出數據到Excel的方法介紹(代碼示例)&#xff0c;有一定的參考價值&#xff0c;有需要的朋友可以參考一下&#xff0c;希望對你有所幫助。之前我們使用PHP導出Excel數據時使用的是PHPExcel庫&#xff0c;但是phpoffice已經官方宣…

sp 導出unity哪個_GitHub上發現的一個導出Unity3D場景數據的工具

1、源地址2、導出腳本腳本名:Unity3DExporter.csC#using UnityEditor;using UnityEngine;using System;using System.Collections.Generic;using System.Linq;using System.IO;public class Unity3DExporter : EditorWindow{private static bool mIsWindowOpen;private bool mE…

poj3422 Kaka's Matrix Travels(最小費用最大流問題)

1 /*2 poj3422 Kakas Matrix Travels 3 不知道 k次 dp做為什么不對&#xff1f;&#xff1f;&#xff1f;4 看了大牛的代碼&#xff0c;才知道還可以這樣做&#xff01; 5 開始沒有理解將a 和 a‘ 之間建立怎樣的兩條邊&#xff0c;導致程序一直陷入死循環&#xff0c;真心花了…

java把對象轉成圖片格式轉換器安卓版,java 萬能圖片格式轉換

話不多說&#xff0c;直接上代碼import java.awt.image.BufferedImage;import java.awt.image.Raster;import java.io.File;import java.io.IOException;import javax.imageio.ImageIO;public class IOUtil {public static void pgm2png(String src, String dest) throws IOExc…

hadooppythonsql_python - hadoop,mapreduce demo

Hadoop,mapreduce 介紹59888745qq.com大數據工程師是在Linux系統下搭建Hadoop生態系統(cloudera是最大的輸出者類似于Linux的紅帽)&#xff0c;把用戶的交易或行為信息通過HDFS(分布式文件系統)等存儲用戶數據文件&#xff0c;然后通過Hbase(類似于NoSQL)等存儲數據&#xff0c…

hdu 2896 病毒侵襲 ac自動機

1 /*2 hdu 2896 病毒侵襲 ac自動機 3 從題意得知&#xff0c;模式串中沒有重復的串出現&#xff0c;所以結構體中可以將last[]&#xff08;后綴鏈接&#xff09;數組去掉 4 last[]數組主要是記錄具有相同后綴模式串的末尾節點編號 。本題中主要是計算每一個模式串5 在主串中有沒…

axure原件 總是丟失_Axure實現提示文本單擊顯示后自動消失的效果

FORM一 .新增的input輸入屬性 1.email類型 在表單提交E-mail地址時,無效的輸入會生成很多無效數據,對后期的數據檢索造成一定的影響.所以在表單提交之前,需要對輸入的E-mail地址進行有效 ...Google的Protobuf協議分析protobuf和thrift類似,也是一個序列化的協議實現,簡稱PB(下文…