四则运算(二叉树)

上传人:飞*** 文档编号:47525564 上传时间:2018-07-02 格式:PDF 页数:16 大小:127.08KB
返回 下载 相关 举报
四则运算(二叉树)_第1页
第1页 / 共16页
四则运算(二叉树)_第2页
第2页 / 共16页
四则运算(二叉树)_第3页
第3页 / 共16页
四则运算(二叉树)_第4页
第4页 / 共16页
四则运算(二叉树)_第5页
第5页 / 共16页
点击查看更多>>
资源描述

《四则运算(二叉树)》由会员分享,可在线阅读,更多相关《四则运算(二叉树)(16页珍藏版)》请在金锄头文库上搜索。

1、实验二四则运算(二叉树)一实习目的通过实习,了解并初步掌握设计、 实现较大系统的完整过程,包括系统分析、编码设计、系统集成、以及调试分析,熟练掌握数据结构的选择、设计、实现以及操作方法,为进一步的应用开发打好基础。二实验要求设计一个混合四则运算程序要求: (1)用二叉树方法设计;(2)可接受空格输入;(3)设计二叉树上节点中数据的排序函数;(4)设计计数二叉树中节点个数的函数;(5)打印输出各关节的中间计数结果和最终计数的结果。三实验代码 #ifndef _TREE_H_ #define _TREE_H_ #include #include #include #include using na

2、mespace std; bool IsOperator(string mystring) if(mystring=“-“|mystring=“+“|mystring=“/“|mystring=“*“|mystring=“) return(true); else return(false); bool IsOperator(char ops) if(ops=+|ops=-|ops=*|ops=/|ops=|ops=(|ops=) return(true); else return(false); bool IsOperand(char ch) if(ch=0) float num1=atof(

3、prt-left_child-data.c_str(); float num2=atof(prt-right_child-data.c_str(); if(prt-data=“+“) num=num1+num2; else if(prt-data=“-“) num=num1-num2; else if(prt-data=“*“) num=num1*num2; else if(prt-data=“/“) num=num1/num2; else if(prt-data=“) num=pow(num1,num2); coutdata=suzzy; prt-left_child=NULL; prt-r

4、ight_child=NULL; else if(prt-left_child=NULL else evaluate(prt-left_child); evaluate(prt-right_child); evaluate(prt); void clear_help(node_type *rt) if(rt!=NULL) clear_help(rt-left_child); clear_help(rt-right_child); delete rt; void clear() clear_help(root); void count_help(node_type *rt,int int f1,

5、f2; if(rt!=NULL) count_help(rt-left_child,f1); count_help(rt-right_child,f2); a=f1+f2+1; int counter() int a; count_help(root,a); return a; ; node_type *build_node(string x) node_type *new_node; new_node=new node_type(x); return(new_node); void binary_tree:print(node_type *p) if(p!=NULL) print(p-lef

6、t_child); print(p-right_child); coutdatadata); copy(r1-left_child,r2-left_child); copy(r1-right_child,r2-right_child); #endif #include #include #include #include bool isok(string exp) char check; int error=0; int lb=0; int rb=0; if(exp.size()=1 |exp.size()=0 else if(IsOperator(exp0) for(int m=0;mNod

7、eStack; stackOpStack; string infix; char choice=y; char c; while(choice=y|choice=Y) coutright_child=temp_tree.root; temp_tree.root=NULL; copy(temp_tree.root,NodeStack.top().root); etree.root-left_child=temp_tree.root; NodeStack.pop(); temp_tree.root=NULL; copy(temp_tree.root,etree.root); NodeStack.p

8、ush(temp_tree); etree.root=NULL; OpStack.push(c); else if(c=() OpStack.push(c); if(infixi+1=-) binary_tree temp; temp.root=build_node(“0“); NodeStack.push(temp); OpStack.push(-); +i; else if(c=) while(OpStack.top()!=() binary_tree temp_tree; string thisstring=“; thisstring=thisstring+OpStack.top();

9、OpStack.pop(); etree.root=build_node(thisstring); copy(temp_tree.root,NodeStack.top().root); NodeStack.pop(); etree.root-right_child=temp_tree.root; temp_tree.root=NULL; copy(temp_tree.root,NodeStack.top().root); etree.root-left_child=temp_tree.root; NodeStack.pop(); if(!IsOperator(etree.root-right_

10、child-data) a = etree.root-left_child-data; b = etree.root-right_child-data; float num1=atof(a.c_str(); float num2=atof(b.c_str(); if(num1 left_child-data = b; etree.root-right_child-data = a; temp_tree.root=NULL; copy(temp_tree.root,etree.root); NodeStack.push(temp_tree); etree.root=NULL; OpStack.p

11、op(); while(!OpStack.empty() binary_tree temp_tree; string thisstring=“; thisstring=thisstring+OpStack.top(); OpStack.pop(); etree.root=build_node(thisstring); copy(temp_tree.root,NodeStack.top().root); NodeStack.pop(); etree.root-right_child=temp_tree.root; temp_tree.root=NULL; copy(temp_tree.root,

12、NodeStack.top().root); etree.root-left_child=temp_tree.root; NodeStack.pop(); temp_tree.root=NULL; if(!IsOperator(etree.root-right_child-data) a = etree.root-left_child-data; b = etree.root-right_child-data; float num1=atof(a.c_str(); float num2=atof(b.c_str(); if(num1 left_child-data = b; etree.root-right_child-data = a; copy(temp_tree.root,etree.root); NodeStack.push(temp_tree); if(!OpStack.empty() etree.root=NULL; coutdata: “; cinchoice; else cout: “; cinchoice; return 0; 四实验结果

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 行业资料 > 其它行业文档

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号