表达式构建二叉树(中缀,前缀,后缀)

表达式构建二叉树(中缀,前缀,后缀)
表达式构建二叉树(中缀,前缀,后缀)

// TheRealBinaryTreeOfMine.cpp : 定义控制台应用程序的入口点。

//

#include"stdafx.h"

#include

#include

#include

#include

#include

using namespace std;

class BinaryNode{

public:

char date;

BinaryNode * leftchild;

BinaryNode * rightchild;

BinaryNode(){

date = 0;

leftchild = NULL;

rightchild = NULL;

}

BinaryNode(char ch){

date = ch;

leftchild = NULL;

rightchild = NULL;

}

};

int first_or_last(char a, char b); //判断两个运算符的优先级;

bool isOP(char ch); //判断该字符是否属于操作符;BinaryNode* Build_BinaryTree(BinaryNode* &BT, string str);//根据中缀表达式构建一颗二叉树;

void Last(BinaryNode *bt); //后序遍历二叉树(递归);

void First(BinaryNode *bt); //先序遍历二叉树(递归);

void Inn(BinaryNode *bt); //中序遍历二叉树(递归);

string Exp_turn(string s); //后缀表达式转换成中缀表达式;

string Exp_turn_and_turn(string s); //前缀表达式转换为中缀表达式;

int choice(char c, char d); //判断表达式属于什么类型的表达式(中缀,后缀,前缀);

void Print(BinaryNode *bt); //打印二叉树(层序遍历,层层打印二叉树);int first_or_last(char a, char b){

if (a == '/' || a == '*'){

if (b == '+' || b == '-')

return 1;

if (b == '/' || b == '*')

return 0;

else

return 0;

}

if (a == '+' || a == '-'){

if (b == '+' || b == '-')

return 0;

if (b == '/' || b == '*')

return 0;

else

return 0;

}

else

return 0;

}

bool isOP(char ch)

{

string OP = { '+', '-', '*', '/', '(', ')' };

for (int i = 0; i < 6; i++){

if (ch == OP[i])

return true;

}

return false;

}

BinaryNode* Build_BinaryTree(BinaryNode* &BT, string str){ queue aQ;

BinaryNode * root = BT;

if (str[0] == '('){

root = new BinaryNode(str[2]);

BT = new BinaryNode(str[1]);

BinaryNode *R = root;

aQ.push(BT);

int j = 3;

while (str[j] != '\0')

{

if (!isOP(str[j]))

{

BT = new BinaryNode(str[j]);

aQ.push(BT);

j++;

}

else

{

if (str[j] == ')' || str[j] == '(')

{

}

else

{

BT = new BinaryNode(str[j]);

root->leftchild = aQ.front();

//cout << root->leftchild->date;

root->rightchild = BT;

//cout << root->rightchild->date;

aQ.pop();

root = BT;

}

j++;

}

}

root->leftchild = aQ.front();

//cout << root->leftchild->date;

aQ.pop();

root->rightchild = aQ.front();

//cout << root->rightchild->date;

aQ.pop();

return R;

}

else{

root = new BinaryNode(str[1]);

BT = new BinaryNode(str[0]);

BinaryNode *R = root;

aQ.push(BT);

int j = 2;

while (str[j] != '\0')

{

if (!isOP(str[j]))

{

BT = new BinaryNode(str[j]);

aQ.push(BT);

j++;

}

else

{

if (str[j] == '(' || str[j] == ')')

{

}

else

{

BT = new BinaryNode(str[j]);

root->leftchild = aQ.front();

//cout << root->leftchild->date;

root->rightchild = BT;

//cout << root->rightchild->date;

aQ.pop();

root = BT;

}

j++;

}

}

root->leftchild = aQ.front();

//cout << root->leftchild->date;

aQ.pop();

root->rightchild = aQ.front();

//cout << root->rightchild->date;

aQ.pop();

return R;

}

}//中缀表达式构建了二叉树函数(消除了‘(’和‘)’)

void Last(BinaryNode *bt){

if (bt){

Last(bt->leftchild);

Last(bt->rightchild);

cout << bt->date;

}

}//后序遍历函数

void First(BinaryNode *bt){

if (bt){

cout << bt->date;

First(bt->leftchild);

First(bt->rightchild);

}

}//先序遍历函数

void Inn(BinaryNode *bt){

if (bt){

Inn(bt->leftchild);

cout << bt->date;

if (bt->rightchild)

{

if (isOP(bt->rightchild->date) && first_or_last(bt->date, bt->rightchild->date) == 1){ cout << "(";

Inn(bt->rightchild);

cout << ")"; //考虑root与root->leftchild操作符的优先级,如果root 的优先级较大则需要添加小括号;

}

else

Inn(bt->rightchild);

}

}

}

string Exp_turn(string s){

queue bQ;

stack bS;

int k = 0;

while (s[k] != '\0'){

if (!isOP(s[k])){

bQ.push(s[k]);

}

else

{

bS.push(s[k]);

}

k++;

} //实现了数字与操作符的分离

char ss[30];

int g = 0;

while (!bQ.empty())

{

ss[g] = bQ.front();

bQ.pop();

g++;

if (!bS.empty()){

ss[g] = bS.top();

bS.pop();

g++;

}

}

ss[g] = '\0';

return ss;

} //实现了后缀表达式转换成中缀表达式;string Exp_turn_and_turn(string s){

queue bOP;

queue bNum;

int k = 0;

while (s[k] != '\0'){

if (!isOP(s[k])){

bNum.push(s[k]);

}

else

{

bOP.push(s[k]);

}

k++;

} //实现了数字与操作符的分离char ss[30];

int g = 0;

while (!bNum.empty())

{

ss[g] = bNum.front();

bNum.pop();

g++;

if (!bOP.empty()){

ss[g] = bOP.front();

bOP.pop();

g++;

}

}

ss[g] = '\0';

return ss;

} //实现了前缀表达式转换为中缀表达式;void Print(BinaryNode *bt){

cout << endl << endl;

queue qQ;

char strstr[30];

int t = 0;

if (bt){

qQ.push(bt);

}

while (!qQ.empty()){

bt = qQ.front();

strstr[t] = bt->date;

t++;

qQ.pop();

if (bt->leftchild != NULL)

qQ.push(bt->leftchild);

if (bt->rightchild != NULL)

qQ.push(bt->rightchild);

} //采用非递归的方法层序遍历二叉树,并将序列记

录在一个数组当中,元素个数为t个

strstr[t] = '\0';

int x = 10, y = 5;;

for (int m = 0; m < x; m++){

cout << ' ';

}

cout << strstr[0] << endl;

int e = 1;

for (int n = 0; n < log2(t + 1); n++){ //此处log2(t+1)是计算该二叉树的深度

for (int v = 0; v < x - y; v++){

cout << ' ';

}

cout << strstr[e];

e++;

int z = 0;

for (z = 0; z < 10; z++){

cout << ' ';

}

cout << strstr[e];

e++;

x = x + y;

cout << endl;

}

}

int choice(char c, char d){

if (isOP(c))

return 1;

if (!isOP(c) && !isOP(d))

return 2;

if (!isOP(c) && isOP(d))

return 3;

else

return 0;

}

int_tmain(int argc, _TCHAR* argv[])

{

BinaryNode *BTree, *R;

string s;

cout << "请输入一个表达式:" << endl;

cin >> s;

string ss;

int temp;

if (s[0] == '(')

temp = choice(s[1], s[2]);

else

temp = choice(s[0], s[1]);

switch (temp)

{

case 1:{

ss = Exp_turn_and_turn(s);

R = Build_BinaryTree(BTree, ss);//构建一颗二叉树;

cout << "前缀表达式,后缀表达式,中缀表达式分别为:" << endl << endl;

First(R);//前序遍历;

cout << endl;

Last(R);//后序遍历;

cout << endl;

Inn(R);//中序遍历(考虑了小括号)

cout << endl;

cout << endl << "二叉树树形打印" << endl;

Print(R);

break;

}

case 2:{

ss = Exp_turn(s);

R = Build_BinaryTree(BTree, ss);//构建一颗二叉树;

cout << "前缀表达式,后缀表达式,中缀表达式分别为:" << endl;

First(R);//前序遍历;

cout << endl;

Last(R);//后序遍历;

cout << endl;

Inn(R);//中序遍历(考虑了小括号)

cout << endl;

cout << endl << "二叉树树形打印" << endl;

Print(R);

break;

}

case 3:{

ss = s;

R = Build_BinaryTree(BTree, ss);//构建一颗二叉树;

cout << "前缀表达式,后缀表达式,中缀表达式分别为:" << endl;

First(R);//前序遍历;

cout << endl;

Last(R);//后序遍历;

cout << endl;

Inn(R);//中序遍历(考虑了小括号)

cout << endl;

cout << endl << "二叉树树形打印" << endl;

Print(R);

break;

}

default:

break;

}

system("PAUSE");

return 0;

}

常见前缀与后缀 英语 附加习题及答案

常见前缀与后缀1. 常见前缀

2. 名词后缀 3 . 形容词后缀

4. 动词后缀 5. 副词后缀 -ly是最常见的副词后缀, 可以附加在形容词后,构成与原形容词意义相同的副词。如:slowly 缓慢地happily高兴地truly 真实地wholly 全部地simply 纯粹地

练习 1. 动词、介词、冠词、物主代词等词后一般接名词或动名词, 如果所给单词是其它词类, 就要将其改为名词, 并注意名词数的变化。 (1)Do you know the ______ (deep) of the river? (2)His _____ (careful) resulted in the terrible accident (3)He is one of the ______ (science) who support this theory. 答案:(1) depth (2) carelessness (3) scientists 2. 动词、介词后一般接名词或动名词, 如果所给单词为动词,就要看该动词是否有名词形式,如果有名词形式,就用其名词形式;如果该动词没有名词形式,就用其动名词。如: (1)Please pay ________ (attend) to your handwriting. (2) His _______ (arrive) made the situation worse. (3)The teacher was angry at my _________ (come) late. 答案:(1) attention (2) arrival (3) coming 3. 动词前后、形容词前后可有副词。如果所需词为副词时, 还要考虑副词级的变化。如: (1)The boy ran ______ (quick) to school. (2)“What’s that?”Father shouted ______ (angry). (3)The little girl is ______(extreme)eager to know the result of the exam。 (4). He was very tired after doing this for a whole day, but he felt very happy since the crop did “grow”______ (height). 答案:(1) quickly (2) angrily (3) extremely (4) higher 4. 在名词前作定语,在系动词后做表语,以及作主语或宾语的补足语时,通常要用形容词如果所需词为形容词时, 还要考虑形容词级的变化。 (1) What’s the ________ (width) river in the world? (2) The _______ (strength) we become, the more modest we should be. 答案:(1) widest (2) stronger 5即时训练 单句填空:用所给单词的适当形式填空。 1. Mary was very ______ at the news, so she looked ______ at her husband, her eyes full of ______ (sad). 2. He ________football very well and he was one of the best ______ in yesterday’s football match. (play) 3. Look! How ________ Kate is laughing! She seems to be the ______ girl in the world (happy). 4. To our ______, the headmaster was very ______ with our report. (satisfy) 5. Edison was a great ________. During his life he had many ______. (invent) 6. I should ________ my task and make it ________ to finish it. (simple) 7. The boy having the ________ of being half starved ________, never to be seen again. (appear) 8. The police _____ the pot and ______ a plot against the President. (cover) 9. You are so _______ to help me. Thank you for your ________. (kindly)

(完整版)常用前缀后缀

常用前缀后缀 一.表示否定的前缀 1.dis-加在名词、形容词,动词之前。 disadvantage(缺点)dishonorable(不光彩的)disagree(不同意) 2.in-加在形容词,名词之前 incorrect(不正确的),inability(无能,无力),inaccurate(不准确的) 3.im-加在字母m,b,p之前 impossible(不顺能的),impolite(不礼貌的),impudence(厚颜无耻) 4.il-加在以1开头的词前 illegal(非法的),illiterate(文盲的,无文化的)illogical(不合逻辑的) 5.ir-加在以r开头的词前 irregular(不稳定的),irresistable(不可抵抗的),irresolvable(不能分解的,不能解决的) 6.un-加在名词,形容词,副词之前 unfinished(未完成的)undoubted(无疑的)unemployment(失业) 7.non-加在形容词,名词前 non-existence(不存在),non-essential(不主要的),non-electrical(非电的) 8.mis-加在动词、名词之前 misunderstand(误解),misjudge(误判),misleading(误导),misfortune(不幸) 9.de-加在名词,形容词之前 demobilize(遣散;使…复员) decolor (脱色, 漂白) 10.anti-加在名词、形容词之前 anti-Japanese(抗日战争),anti-social(厌恶社会的,反社会的),antidite(解毒药) 11.counter-加在名词、动词前 counterattack(反攻,反击),counteract(抵抗,阻碍)counterrevolution(反革命) 二.表示“前before”的前缀 1.pre- preconception(成见),pre-exsiting(先于……而存在的),pre-selection(选举前的) preface(前言) 2.ante- anteroom(前室,接待室),antecessor(先行者,先驱者) 3.fore- forehaed(前额),foreground(前景),foreman(工头,领班),foresee(预见,先见),foretell(预言) 4.pro- programme(计划),prologue(序幕) 5.ex- ex-president(前任总统)ex-wife(前妻) 三.表示“后-post”的前缀 1.post- post-war(战后),post-position(后置词),postmeridian(下午) 四.表示“低”、“下”的前缀 1.hypo- hypocrisy(伪善,虚伪),hypothesis(假设),pypocholoride(次氯酸盐) 2.Infra- infra-red(红外线),infrahuman(低于人类的),infrasonic(亚声的,次声的) 3.sub- sub-editou(副编辑),sub-way(地铁),sub-conscious(下意识的),submarine(海下的),subtropical(亚热带的),subtitle(副标题)

表达式二叉树·实验代码

实验:表达式二叉树 实验要求: 建立表达式二叉树,并打印(可逆时针旋转90度打印,也可尝试正向打印) 以中缀表达式a*b+(c-d)/e-f 为例,建立以"-"号为根的表达式二叉树。 提示:若直接利用中缀表达式建立困难,可先将中缀表达式转化为后缀表达式(可利用栈中的中缀到后缀转化程序实现中缀表达式到后缀表达式的转换,再根据后缀表达式建立表达式二叉树,可参考栈中后缀表达式计算方法)。 实验代码: #include #include #include #include #include using namespace std; class tnode; void buildexptree(const string &exp); void printexptree(); int judgerank(char ch); bool isoperator(char ch); void test(); void setxy(tnode *tn, int y); int X = 0; int Y = 0; int depth = 0; vectorvt; class tnode{ public: char nodeV alue; int x, y; tnode *left; tnode *right;

tnode(){ x = 0; y = 0; } tnode(char &item, tnode *lptr = NULL, tnode *rptr = NULL): nodeV alue(item), left(lptr), right(rptr){ x = 0; y = 0; } }; tnode *myNode; bool cmp(tnode *t1, tnode *t2){ if(t1->y != t2->y) return (t1->y) > (t2->y); return (t1->x) < (t2->x); } class zpair{ //将operator和rank打包为一体,临时存储在stk2中public: char op; int rank; zpair(){} zpair(char _op, int _rank){ op = _op; rank = _rank; } }; int judgerank(char ch){ if(ch == '(') return -1; if(ch == '+' || ch == '-') return 1; if(ch == '*' || ch == '/') return 2; return 0; } bool isoperator(char ch){ if(ch == '(' || ch == ')' || ch == '+' || ch == '-' || ch == '*' || ch == '/') return true; else return false; }

最常见的前缀和后缀

英语中的派生词的构成主要有三种:合成(由两个或两个以上的单词合成的单词);派生(指一个词根加上前缀或后缀构成的单词);转化(一种词性转化成另一种或几种词性的单词)。本文重点通过对前缀和后缀的剖析解读派生词的意义和特点。 先看下表: 一、前缀 1. dis- 表示意义相反,主要用在动词之前,间或用于名词或形容词前。如: appear (v.出现) → disappear (v.消失), 再如: dislike不喜欢 discover 发现 disobey不遵从 disbelieve 不相信 dishonest(adj.)不诚实的 disadvantage (n.) 不利条件,缺点 2. in-, im-, un-, il-, ir-用在形容词前,表示否定意义。如: indirect 间接的 incorrect 不正确的 inactive 不活动的

impossible 不可能的 unable 不能的 unhealthy 不健康的 unsuccessful 不成功的 uncommon不普通的 unpleasant令人不快的 unfortunate不幸的 irregular不规则的 illegal非法的 invisible看不见的 3. re- 表示“重新,再”,用在动词前。如: rebuild 重新建造 recycle 再循环 reconsider 重新考虑 review 复习二、后缀 I.形容词后缀 1. -able (n./v.→adj.)表示“可以……的;显示……性质”。如:respectable 可敬的 eatable 可吃的 comfortable 舒服的 valuable 有价值的 fashionable 时髦的 loveable 可爱的 2. -ful (n./v.→adj.) 表示“充满……的”。如: beautiful 漂亮的 successful 成功的 wonderful 精彩的 mouthful 满嘴的 shameful 可耻的 hopeful 充满希望的 3. -less (n.→adj.) 表示“没有……的”。如: jobless 无业的 cordless 无线的 homeless 无家可归的 helpless 无助的 4. -ous (n.→adj.)表示“具有……性质的”。如: nervous 紧张的 famous 著名的 dangerous 危险的 poisonous 有毒的 mountainous 山区的 humorous 幽默的

第6章树和二叉树习题

第六章 树和二叉树 一、选择题 1.算术表达式a+b*(c+d/e )转为后缀表达式后为( B ) A .ab+cde/* B .abcde/+*+ C .abcde/*++ D .2. 设有一表示算术表达式的二叉树(见下图), 它所表示的算术表达式是( C ) A. A*B+C/(D*E)+(F-G) B. (A*B+C)/(D*E)+(F-G) C. (A*B+C)/(D*E+(F-G )) D. A*B+C/D*E+F-G 3. 设树T 的度为4,其中度为1,2,3和4的结点个数分别为4,2,1 ,1 则T 中的叶子数为( D ) A .5 B .6 C .7 D .8 4. 在下述结论中,正确的是( D ) ①只有一个结点的二叉树的度为0; ②二叉树的度为2; ③二叉树的左右子树可任意 交换; ④深度为K 的完全二叉树的结点个数小于或等于深度相同的满二叉树。 A .①②③ B .②③④ C .②④ D .①④ 5. 设森林F 对应的二叉树为B ,它有m 个结点,B 的根为p,p 的右子树结点个数为n,森林F 中第一棵树的结点个数是( A ) A .m-n B .m-n-1 C .n+1 D .条件不足,无法确定 6.若一棵二叉树具有10个度为2的结点,5个度为1的结点,则度为0的结点个数是( B ) A .9 B .11 C .15 D .不确定 7.设森林F 中有三棵树,第一,第二,第三棵树的结点个数分别为M1,M2和M3。与森林F 对应的二叉树根结点的右子树上的结点个数是( D )。 A .M1 B .M1+M2 C .M3 D .M2+M3 8.一棵完全二叉树上有1001个结点,其中叶子结点的个数是( E ) A . 250 B . 500 C .254 D .505 E .以上答案都不对 9. 有关二叉树下列说法正确的是( B ) A .二叉树的度为2 B .一棵二叉树的度可以小于2 C .二叉树中至少有一个结点的度为2 D .二叉树中任何一个结点的度都为2 10.二叉树的第I 层上最多含有结点数为( C ) A .2I B . 2I-1-1 C . 2I-1 D .2I -1 11. 一个具有1025个结点的二叉树的高h 为( C ) A .11 B .10 C .11至1025之间 D .10至1024之间 12.一棵二叉树高度为h,所有结点的度或为0,或为2,则这棵二叉树最少有( B )结点 A .2h B .2h-1 C .2h+1 D .h+1 13. 一棵树高为K 的完全二叉树至少有( C )个结点 A .2k –1 B. 2k-1 –1 C. 2k-1 D. 2 k 14.对二叉树的结点从1开始进行连续编号,要求每个结点的编号大于其左、右孩子的编号,同一结点的左右孩子中,其左孩子的编号小于其右孩子的编号,可采用( C )次序的遍历 实现编号。 A .先序 B. 中序 C. 后序 D. 从根开始按层次遍历 15.一棵二叉树的前序遍历序列为ABCDEFG ,它的中序遍历序列可能是( B )

算术表达式与二叉树

目录 一、系统开发的背景 (1) 二、系统分析与设计 (1) (一)系统功能要求 (1) (二)系统模块结构设计 (1) 三、系统的设计与实现 (3) (一)二叉树的遍历 (3) (二)算术表达式求值 (5) 四、系统测试 (9) (一)测试二叉树遍历函数 (9) (二)测试算术表达式求值函数 (10) 五、总结 (10) 六、附件(代码、部分图表) (10) (一)程序代码 (10) (二)实验截图 (15)

算术表达式与二叉树 一、系统开发的背景 为了方便进行基本的算术运算,减轻对数字较大的数操作时所带来的麻烦,及其在运算过程中错误的避免。因此设计算术表达式与二叉树的程序来解决此问题。 二、系统分析与设计 (一)系统功能要求 由于一个表达式和一棵二叉树之间,存在着自然的对应关系。遍写一个程序,实现基于二叉树表示的算术表达式的操作。算术表达式内可以含有变量(a~z)、常量(0~9)和二元运算符(+,-,*,/,^(乘幂))。 具体实现以下操作: 1以字符序列的形式输入语法正确的前缀表达式并构造表达式。 2用带括弧的中缀表达式输出表达式。 3实现对变量V的赋值(V=c),变量的初值为0。 4对算术表达式E求值。 (二)系统模块结构设计 通过对系统功能的分析,基于二叉树表示的算术表达式的功能 如图(1)所示。

图1:基于二叉树表示的算术表达式的功能图 通过上图的功能分析,把整个系统划分为主要的两大个模块: 1、将语法正确的前缀表达式用二叉树的遍历转换成相应的遍历序列,必要时可以求出此二叉树的结点数及其树的深度。该模块借助函数BiTree Create(BiTree T)创建二叉树,void Preorder(BiTree T) 先序遍历, void InOrder(BiTree T)中序遍历,void PostOrder(BiTree T)后序遍历,int Sumleaf(BiTree T)统计叶结点的数目,int Depth(BiTree T)二叉树的深度6个函数联合来实现; 2、计算中序遍历所得的算术表达式的值。其中先要将扫描得到的中缀表达式转换为后缀表达式,然后利用栈的初始化,进栈与取栈顶元素操作进行对后缀表达式进行计算。该模块借助函数void InitStack(SeqStack *S)初始化栈,int PushStack(SeqStack *S,char e)进栈,int GetTop(SeqStack

C语言 后缀表达式计算

一、设计思想 计算算数表达式并求值,采取的共有两种方法: 1.先将算数表达式转化为后缀表达式,然后对后缀表达式进行计算。 2.对算数表达式进行直接的计算。 第一种算法 这种解决方案又分为两步: 1.将表达式先转化为后缀表达式的字符串数组 2.利用后缀表达式进行计算 在转化过程中,第一,建立一个存符号的栈,和一个字符串数组,用来存放转化以后的表达式 然后,对于得到的用户输入的字符串进行逐个的扫描,如果是数组或者小数点,则直接存放到数组中,并且在后面加入一个分隔符,如果是操作符,则和栈中的已存的进行比较,如果比栈中的操作符的优先级高,则直接入栈,如果优先级低或相等,则栈中元素出栈,存到字符串中,然后再次检查栈顶,直到栈中元素的优先级低于扫描操作符,则此操作符入栈,然后扫描下一个字符,直到遇到字符串的结束符号\0,扫描结束。数组中存的就是后缀表达式。得到后缀表达式后,进行计算,要用到数值栈。首先要将字符表示的数字转化为浮点小数,然后进行扫描,遇到数值,放入栈中,遇到操作符,就从栈中取出两个数,进行计算后再放入栈中,扫描下一个,最后的计算结果就存到了栈中,直接取出栈内元素,就是计算的最后结果。 第二种算发 首先要建立两个栈,一个用来存放操作符,一个用来存放数值。开始对用户输入的字符串进行扫描,如果是数字字符或者小数点,则将字符转化为浮点数存到数栈里,如果是操作符,则观察符号栈,如果栈顶元素的优先级低于观察的操作符,则操作符入栈,如果栈顶元素的优先级高于或者等于观察的操作符,则从数值栈中取出两个浮点数,从符号栈中取出栈顶的操作符,然后进行相应的数值计算,所得的结果再存到数值栈中,重复这样的操作,直到符号栈中栈顶元素的优先级低于观察的操作符,则此操作符入栈,然后对下一个字符进行扫描。如果是左括号,则不进行优先级的比较,直接入栈,入栈后优先级为-1。如果是右括号,则从数值栈中取两个操作数,符号栈中取出一个符号,然后进行计算后得数放入数栈中,不断进行此类操作,直到从栈中取出的是左括号为止,左括号去掉,扫描下一个。扫描结束后,计算也结束了,计算的结果就存放在数值栈中,最后把数值栈中的数取出,就是所得的计算结果。 容错的算法简要: 括号匹配:当扫描到左括号是,左括号直接入栈,扫描到右括号时,则左括号出栈,如果栈为空,则右括号多,如果最后栈中还有括号,则左括号多。给出错误提示。 除数不为0:当扫描到'/'时,就判断其后面的数字是否为0,如果为0报错。 取余运算:取余运算时,操作数判断是否为整数,不为整数报错。 二、算法流程图 第一种算法:先将表达式转化为后缀表达式,然后计算 其主函数流程图为:

常用的前缀和后缀

一、常用的前缀和后缀 1、常用前缀 aero-:concerning the air of aircraft plane—aeroplane space—aerospace anti-:against;opposite of nuclear—antinuclear matter—antimatter war—antiwar auto-:of or by oneself biography—autobiography criticism—autocriticism be-:to treat as the stated thing friend—befriend little—belittle bi-:two;twice;double lingual—bilingual cycle—bicycle bio-:concerning living things chemistry—biochemistry sphere—biosphere by-,bye-:less important produce—by-produce way—byway centi-:hundredth part grade—centigrade meter—centimeter co-:together,with author—coauthor exist—coexist col-:( used before l ) together,with location—collocation com-:( used before b,m,p ) together,with

passion—compassion con-:together,with centric—concentric federation—confederation contra-:opposite diction—contradiction natural—contranatural cor-:( used before r ) together,with relate—correlate respond—correspond counter-:opposite act—counteract attack—counterattack cross-:across;going between the stated things and joining them country—crosscountry breed—crossbreed de-:showing an opposite;to remove;to reduce code—decode value—devalue dis-:not;the opposite of advantage—disadvantage agree—disagree honest—dishonest em-:( used before b,m,p ) to cause to become body—embody power—empower en-:to cause to become;to make danger—endanger large—enlarge ex-:former ( and still living ) minister—ex-minister wife—ex-wife

数据结构实验二叉树

实验六:二叉树及其应用 一、实验目的 树是数据结构中应用极为广泛的非线性结构,本单元的实验达到熟悉二叉树的存储结构的特性,以及如何应用树结构解决具体问题。 二、问题描述 首先,掌握二叉树的各种存储结构和熟悉对二叉树的基本操作。其次,以二叉树表示算术表达式的基础上,设计一个十进制的四则运算的计算器。 如算术表达式:a+b*(c-d)-e/f 三、实验要求 如果利用完全二叉树的性质和二叉链表结构建立一棵二叉树,分别计算统计叶子结点的个数。求二叉树的深度。十进制的四则运算的计算器可以接收用户来自键盘的输入。由输入的表达式字符串动态生成算术表达式所对应的二叉树。自动完成求值运算和输出结果。四、实验环境 PC微机 DOS操作系统或 Windows 操作系统 Turbo C 程序集成环境或 Visual C++ 程序集成环境 五、实验步骤 1、根据二叉树的各种存储结构建立二叉树; 2、设计求叶子结点个数算法和树的深度算法; 3、根据表达式建立相应的二叉树,生成表达式树的模块; 4、根据表达式树,求出表达式值,生成求值模块; 5、程序运行效果,测试数据分析算法。 六、测试数据 1、输入数据:*(+)3 正确结果: 2、输入数据:(1+2)*3+(5+6*7);

正确输出:56 七、表达式求值 由于表达式求值算法较为复杂,所以单独列出来加以分析: 1、主要思路:由于操作数是任意的实数,所以必须将原始的中缀表达式中的操作数、操作符以及括号分解出来,并以字符串的形式保存;然后再将其转换为后缀表达式的顺序,后缀表达式可以很容易地利用堆栈计算出表达式的值。 例如有如下的中缀表达式: a+b-c 转换成后缀表达式为: ab+c- 然后分别按从左到右放入栈中,如果碰到操作符就从栈中弹出两个操作数进行运算,最后再将运算结果放入栈中,依次进行直到表达式结束。如上述的后缀表达式先将a 和b 放入栈中,然后碰到操作符“+”,则从栈中弹出a 和b 进行a+b 的运算,并将其结果d(假设为d)放入栈中,然后再将c 放入栈中,最后是操作符“-”,所以再弹出d和c 进行d-c 运算,并将其结果再次放入栈中,此时表达式结束,则栈中的元素值就是该表达式最后的运算结果。当然将原始的中缀表达式转换为后缀表达式比较关键,要同时考虑操作符的优先级以及对有括号的情况下的处理,相关内容会在算法具体实现中详细讨论。 2、求值过程 一、将原始的中缀表达式中的操作数、操作符以及括号按顺序分解出来,并以字符串的 形式保存。 二、将分解的中缀表达式转换为后缀表达式的形式,即调整各项字符串的顺序,并将括 号处理掉。 三、计算后缀表达式的值。 3、中缀表达式分解 DivideExpressionToItem()函数。分解出原始中缀表达式中的操作数、操作符以及括号,保存在队列中,以本实验中的数据为例,分解完成后队列中的保存顺序如下图所示:

[java入门学习]第 3 章 运算符和表达式.

第 3 章运算符和表达式 运算符指明对操作数所进行的运算。按操作数的数目来分,可以有一元运算 符 (如 ++、--,二元运算符(如 +、>和三元运算符 (如?:,它们分别对应于一个、两个和三个操作数。对于一元运算符来说 ,可以有前缀表达式 (如++i 和后缀表达式 (如 i++,对于二元运算符来说则采用中缀表达式(如a+b。按照运算符功能来分,基本的运算符有下面几类 : 1.算术运算符 (+,-,*,/,%,++,-- 2.关系运算符 (>,<,>=,<=,==,!= 3.布尔逻辑运算符 (!,&&,|| 4.位运算符 (>>,<<,>>>,&,|,^,~ 5.赋值运算符 (=,及其扩展赋值运算符如+= 6.条件运算符 ( ?: 7.其它 (包括分量运算符·,下标运算符 [],实例运算符 instance of,内存分配运算符new,强制类型转换运算符(类型,方法调用运算符 ( 等 本章中我们主要讲述前6类运算符。 § 3.1算术运算符 算术运算符作用于整型或浮点型数据 ,完成算术运算。 一、二元算术运算符 如下表所示运算符用法描述 + op1+op2 加 - op1-op2 减 * op1*op2 乘 / op1/op2 除 % op1%op2 取模(求余

Java对加运算符进行了扩展,使它能够进行字符串的连接 ,如 "abc"+"de",得到 串 "abcde"。我们将在第七章中讲解。与C、 C++不同,对取模运算符%来说,其操作数可以为浮点数, 如 37.2%10=7.2。 二、一元算术运算符 如下表所示 : 运算符用法描述 + +op 正值 - -op 负值 ++ ++op,op++ 加1 -- --op,op-- 减1 i++与 ++i的区别 i++在使用i之后,使 i的值加 1,因此执行完 i++后,整个表达式的值为 i,而 i的值变为 i+1。 ++i在使用i之前,使 i的值加 1,因此执行完 ++i后 ,整个表达式和 i的值均为 i+1。 对 i--与 --i同样。 例 3.1.下面的例子说明了算术运算符的使用 public class ArithmaticOp{ public static void main( String args[] { int a=5+4; //a=9 int b=a*2; //b=18 int c=b/4; //c=4 int d=b-c; //d=14 int e=-d; //e=-14 int f=e%4; //f=-2 double g=18.4;

英语中常用的前缀和后缀

英语中常用的前缀和后缀 aero:concerning the air or aircraft plane(飞机)—aeroplane(飞机) space(空间, 间隔)—aerospace(航空宇宙) anti: against;opposite of nuclear([核]核子的)—antinuclear(反对使用核武器的) matter(物质)—antimatter(反物质) war(战争、作战、打仗)—antiwar(反战的, 反对战争的) auto: of or by oneself biography(传记)—autobiography(自传) criticism(批评, 批判)—autocriticism(自我反省, 自我检讨) be:to treat as the stated thing friend(朋友, 助手)—befriend(待人如友, 帮助) little(很少的, 矮小的,很少)—belittle(轻视, 使渺小, 使...显得渺小)bi: two;twice;double lingual(语言的)—bilingual(能说两种语言的) cycle(自行车)—bicycle(脚踏车, 自行车) bio:concerning living things chemistry(化学)—biochemistry(生物化学) sphere(圈子)—biosphere(生物圈) by—:less important product(产品, 产物,)—by-product(副产品, 附加产物) way(路,道路)—byway(小道) centi: hundredth part grade(等级)—centigrade(分为百度的, 百分度的, 摄氏温度的)meter(米)—centimeter(厘米) co: together, with author(作家, 创造者)—coauthor(合著者, 共同执笔者,合著)exist(存在, 生存)—coexist(共存) col:(used before l) together, with location(位置, 场所)—collocation(排列, 配置) com:(used before b, m, p)together, with passion(激情, 热情)—compassion(同情,怜悯)

表达式用二叉树表示(1)

数据结构程序报告(3) 2011.3.29

2. 需求分析: (1)功能:表达式可以用二叉树表示,对于简单的四则运算,请实现以下功能【1】对于任意给出的前缀表达式(不带括号)、中缀表达式(可以带括号)或后缀表达式(不带括号),能够在计算机内部构造出一棵表达式二叉树,并且图示出来(图形的形式)。 【2】对于构造好的内部表达式二叉树,按照用户的要求输出相应的前缀表达式(不带括号)、中缀表达式(可以带括号,但不允许冗余括)或后缀表达式(不带括号)。 提示:所谓中缀表达式中的冗余括号,就是去掉括号后不影响表达式的计算顺序。例如:“(c+b)+a”中的括号是冗余的,可以表示成不冗余的“c+b+a”。 (2)输入输出要求:请输入字符串表达式: 树形二叉树(图形显示) 中缀表达式为: 前缀表达式为: 后缀表达式为: 3.概要设计:(算法) 分成两部分完成: 【1】前缀、中缀、后缀表达式->二叉树表达式 前缀表达式->二叉树表达式:(a)碰到操作数则把其值赋给相应的新申请的二叉树结点,地址压栈;(b)碰到操作符则把其值赋给相应的新申请的二叉树,并从栈中弹出两个地址,分别作为其右指针和左指针,然后再把其地址压栈,最后一个地址即为二叉树的根结点地址。 中缀表达式->二叉树表达式:把中缀表达式转换成后缀表达式,然后再建立二

叉树。 后缀表达式->二叉树表达式:(a)碰到操作数则把其值赋给相应的新申请的二叉树结点,若栈为空则地址压栈,若非空则取栈顶元素,若栈顶元素的左孩子为空则当前结点设为其左孩子,左孩子为满则设为其右孩子再压栈;(b)碰到操作数则把其值赋给相应的新申请的二叉树结点,取栈顶元素,若栈顶元素的左孩子为空则设为其左孩子,左孩子为满则设为其右孩子开始那个元素地址为根结点地址,开始时用变量root保存。 【1】二叉树表达式->前缀、中缀、后缀表达式 二叉树表达式->前缀表达式:对二叉树表达式进行前序遍历。 二叉树表达式->中缀表达式:对二叉树表达式进行中序遍历,若结点操作符的优先级高于其左或右子树,在打印相应的子树之前先打印开括号,在打印相应的子树最后在打印一个闭括号。 二叉树表达式->后缀表达式:对二叉树表达式进行后序遍历。

c语言实现中缀,后缀,前缀表达式转换并求值

c语言实现中缀,后缀,前缀表达式转 换并求值 c语言实现中缀,后缀,前缀表达式转换并求值九#include #include #define MAXNUM 100 typedef struct Node//定义存储中缀表达式的结点类型{int data; int data1; char data2; struct Node *next; }Lnode; typedef struct Node2//定义存储前缀表达式的结点类型{int data; int data1; char data2; struct Node2 *next; struct Node2 *prior; }Lnode2; typedef int selemtype1;//定义运算数栈的结点typedef struct//定义运算数栈的类型{selemtype1 *base; selemtype1 *top; }sqstack1; void InitStack1(sqstack1 &s)//新建一个空运算数栈{=(selemtype1 *)malloc(MAXNUM*sizeof(selemtype1));

=; if(!) printf(“出错:申请空间失败!\\n”); } void Push1(sqstack1 &s,selemtype1 &e)//运算数栈,入栈:插入元素e为新的栈顶元素{ if(>=MAXNUM) printf(“出错:表达式过长!1\\n”); *++ =e; } void GetTop1(sqstack1 s,selemtype1 &e)//运算数栈,用e返回栈顶元素{e=*(); } void Popopnd1(sqstack1 &s,selemtype1 &e) //运算数栈,退栈:删除栈顶元素,并用e返回其值{e=*--; } int stackempy1(sqstack1 s) //运算数栈,若为空栈返回1,否则返回0 {if(==) return 1; else return 0; } typedef char selemtype2;//定义运算符栈的结点类型typedef struct//定义运算符栈类型{selemtype2 *base; selemtype2 *top; }sqstack2; void InitStack2(sqstack2 &s)//新建一个空运算符栈{=(selemtype2 *)malloc(MAXNUM*sizeof(selemtype2)); =; if(!) printf(“出错:申请空间失败!

常见的前后缀

常见得前缀 一、表示否定意义得前缀 un-不做相反动作dis-不做相反动作in- 不 im-不ir-不il- 不non- 不,非 【猜一猜】①unhappy ②untrue ③undress④undo⑤disagree(ment)⑥disown ⑦disinect ⑧non-existent⑨non-conductor 【key】①不高兴②不真实③暴露,使卸去装饰④解开,松开⑤不一致,不适合(争执,争论) ⑥否认⑦消毒⑧不存在得⑨绝缘体 二、表示前,先前意义得前缀 husband ex—husband(前夫) see oresee(预知,预见) history prehistory(史前时期) claim proclaim(宣告,宣布) 瞧完这单词得对比大家一定知道这一组前缀主要就是表示前,先前,预先 前缀ex-,汉语意思就是“先前",它主要就是与表示“人”得名词搭配、 例如:ex—minister-ormerminister(前任大使) 前缀ore-,汉语意思就是“先前得”、“在前面得”,它可以加在某些动词与名词前面。例如:oretell预言前缀pre—,汉语意思就是“在……前”,它主要就是加在名词前面,也与少量得形容词、动词搭配、 前缀pro—,汉语意思就是“向前,在前,预先”,可以与名词、动词、形容词搭配。 例如:propelling(向前推进得) 【猜一猜】①ex-president ②orecast ③orecourt④orehead ⑤oreground⑥preadult ⑦preannounce ⑧precook ⑨preace 【key】①前任总统②预见,预测③前院,(篮球)前(场)球④前额,(任何事物得)前部⑤前景,最显著得位置⑥成年前得⑦预告,事先宣告⑧预煮,预先烹调(食物)⑨前言 三、表示错误得,不良意义得前缀 spell misspell拼错 treat maltreat虐待,滥用 根据前面单词得比较我们能得出 mis—错误地mal-不良得 【猜一猜】①misinorm ②malunction 【key】①告诉错误得消息②故障 四、表示空间位置、方向关系得前缀 请大家熟记下面得顺口溜里in(im,inter, intro)外out。上over(super,up)下sub(under)、前pro(pre)后po st。还有中间就是medi(med,mid)、 前缀意义例词 in—,im-表示“向内,在内,背于”inside里面;import进口 inter-,intel—表示“在……间,相互”international国际得;internet互联网 intro-表示“向内,在内,内侧”introduce介绍 en—表示“在内,进入”encage 关在笼中,把…关起来 out—表示“在上面,在外部,在外”outline 大纲,轮廓,略图;outside外面 ex-,ec—,es-表示“外部,外”exit,出口;expand 扩张,张开,发展 extra- 表示“额外”extraction提取 up—表示“向上,向上面,在上”upward在上面地,向上地;uphold 支持,

最常见的前缀和后缀

1 / 5 英语中的派生词的构成主要有三种: 合成(由两个或两个以上的单词合成的单词);派生(指一个词根加上前缀或后缀构成的单词);转化(一种词性转化成另一种或几种词性的单词)。本文重点通过对前缀和后缀的剖析解读派生词的意义和特点。 先看下表: 词缀 特点 类别前缀通常不改 变词性词义词类 agree (v.)→ disagree(v.) 同意→不同意 health (n.)→ healthy (adj.) 健康→健康的 care (n.)→ careless (adj.) 小心→粗心的 意义改变后缀一般改变 2 / 5 词性词义改变不 大, 但否定意义后

缀除外 一、前缀 1. dis-表示意义相反,主要用在动词之前,间或用于名词或形容词前。如: appear (v.出现) →disappear (v.消失), 再如: dislike不喜欢discover发现disobey不遵从disbelieve不相信dishonest(adj.)不诚实的disadvantage (n.)不利条件,缺点2. in-, im-, un-, il-, ir-用在形容词前,表示否定意义。如:indirect间接的incorrect不正确的inactive不活动的impossible不可能的unable不能的unhealthy不健康的unfortunate不幸的irregular不规则的illegal非法的 invisible看不见的 3. re-表示“重新,再”,用在动词前。如: rebuild重新建造recycle再循环reconsider重新考虑review复习二、后缀 I.形容词后缀 1. -able (n./v.→adj.)表示“可以??的;显示??性质”。如:valuable有价值的fashionable时髦的loveable可爱的 3 / 5 2. -ful (n./v.→adj.) 表示“充满??的”。如: beautiful漂亮的successful成功的wonderful精彩的 mouthful满嘴的shameful可耻的hopeful充满希望的

相关文档
最新文档