标识符树与表达式求值

上传人:z**** 文档编号:170023741 上传时间:2022-11-18 格式:DOCX 页数:6 大小:28.24KB
返回 下载 相关 举报
标识符树与表达式求值_第1页
第1页 / 共6页
标识符树与表达式求值_第2页
第2页 / 共6页
标识符树与表达式求值_第3页
第3页 / 共6页
点击查看更多>>
资源描述
1实验目的(1)掌握二叉树的数组存储方法。(2)掌握二叉树的非线性特点、递归特点和动态特性。(3)复习二叉树遍历算法和标识符树的概念。(4)利用标识符树的后序计算表达式的值(运算只涉及+、-、*、/)2实验内容(1)定义二叉树的结构如下:struct tree int data;struct tree *left;struct tree *right;typedef struct tree btnode;typedef btnode *bt;/ 定义结构体/ 定义一个整型数据域/ 定义左子树指针/ 定义右子树指针/ 树的结构类型/ 定义树结点的指针类型(2)把算术表达式2*3+6/3的标识树(如下图)存入一维数组。(3) 求标识符树的前序遍历、中序遍历和后序遍历的 序列。(4) 以后序计算标识符树的值。3 参考程序#include#includestruct tree/ 树的结构声明char data;/ 结点数据/ 指向左子树的指针/ 指向右子树的指针;typedef struct tree treenode;/ 树的结构新类型typedef treenode *btree;/ 声明树结点指针类型int n;n计算字符串长度btree createbtree(int *data,int pos) 树/ 创建表达式二叉btree newnode;/ 新结点指针if (datapos=0|posn)/ 终止条件return NULL;elsenewnode=new treenode;/ 创建新结点内存newnode-data=datapos;/ 创建结点内容struct tree *left;struct tree *right;/ 创建左子树递归newnode-left=createbtree(data,2*pos);调用newnode-right=createbtree(data,2*pos+1); / 创建右子树递归调用return newnode;void 输出preorder(btree ptr)/ 表达式二叉树前序/ 终止条件/ 输出结点内容/ 左子树/ 右子树/ 表达式二叉树中/ 终止条件/ 左子树/ 输出结点内容/ 右子树/ 表达式二叉树后序/ 右子树/ 左子树/ 右子树/ 输出结点内容if(ptr!=NULL)printf( %c,ptr-data);preorder(ptr-left); preorder(ptr-right);void inorder(btree ptr)序输出if (ptr!=NULL)inorder(ptr-left);printf( %c,ptr-data); inorder(ptr-right);void postorder(btree ptr)输出if(ptr!=NULL)postorder(ptr-left);postorder(ptr-right);printf( %c,ptr-data);/ 表达式二叉树/ 定义操作数变量1/ 定义操作数变量2/ 对/ 终止条件/字符数字转为数值/ 左子树/ 右子树/ 计算二叉int cal(btree ptr)后序计值int operand1=0;int operand2=0;int getvalue(int op,int operand1,int operand2);getvalue函数作声明if (ptr-left=NULL & ptr-right=NULL)return ptr-data-48;esleoperand1=cal(ptr-left);operand2=cal(ptr-right);return getvalue(ptr-data,operand1,operand2) int getvalue(int op,int operand1,int operand2) 树表达式值switch(char)op)case*:return(operand1*operand2);case/:return(operand1/operand2);case+:return(operand1+operand2);case-:return(operand1-operand2);void main() / 主程序/ 表达式二叉树指针/ 定义输出结果变btree root=NULL;int result,k=1; 量int data100= ;char ch;prin tf(按前序输入标识符树的结点数据,以回车键表示结束n);while(ch=getchar()!=n)datak+=ch;datak=0;n=k-1;root=createbtree(data,1); 二叉树printf(tn 前序表达式:);preorder(root);printf(tnn 中序表达式:);inorder(root);/ 创建表达式/ 前序输出二叉树/ 中序输出二叉树printf(tnn 后序表达式:);/ 后序输出二叉树/ 计算postorder(root);result=cal(root);printf(tnn 表达式结果是:dnn,result);/输出计算结果 4程序运行运行本程序,按标识符树的前序序列,把:+,*,/,2,3,6,3存入一维数组data,所以程序运行以后就能输出结果如下:按前序输入标识符树的结点数据,以回车键表示结車+*z2363前序表达式;+ * 2 3 / & 3中序表迖式:2 * 36 / 3后序表达式:2 3 * 6 3 / +表迖式结杲是:8注意:字符之间不允许空格,数值只能是一位。5算法分析Createbtree函数的时间复杂度为:t (n)=O(n)。 1preorder函数的时间复杂度为:t (n)=0(n)。2inorder函数的时间复杂度为:t (n)=0(n)。3postorder函数的时间复杂度为:t (n)=0(n)。4cal函数的时间复杂度为:t (n)=O(n)。5get value函数的时间复杂度为:t (n)=O(l)。6
展开阅读全文
相关资源
相关搜索

最新文档


当前位置:首页 > 建筑环境 > 建筑资料


copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!