一棵采用孩子兄弟表示法存储的树,设计算法,按层次依次输出该树的所有结点

用队列啊

1.输出根
2.将根进队列保存,将指针移到该根的右孩子。
3.指针不为空则重复1,2一直到指针为空
4.如果队列不为空,则出队列头,指针移到队列头的左孩子,重复1-4直到队列为空
温馨提示:内容为网友见解,仅供参考
第1个回答  2011-04-20
8 4 2 - / 输出 4

//每一个表达式是一个由数个String构成的list,list中每一个Sting是算术表达式的一个数字或一个运算符,如["8","4","2","-","/"]
//运算符只支持+,-,*,/

public double rpn (List<String> input)
{
Stack<String> s = new Stack<String>();
Iterator it = input.interator();
while(it.hasNext()){
String str = it.next();
if(str.charOf(0)>='0' && str.charOf(0)<='9')
s.push(str);
else if(str.charOf(0) == '+' || str.charOf(0) == '-' || str.charOf(0)=='*' ||str.charOf(0) == '/'){
double temp = 0.0;
char op = str.charOf(0);
Float f1 = Float.valueOf(s.pop());
Float f2 = Float.valueOf(s.pop());
switch(op){
case '+': temp = f1 + f2; break;
case '-': temp = f2 - f1; break;
case '*': temp = f2 * f1; break;
case '/': if(f1 == 0) throw new ArithmaticException(); temp = f2 / f1; break;
}
s.push(String.valueOf(temp));
}
else
throw new IllegalArgumentException();
}
return Float.valueOf(s.pop());
}
另外,虚机团上产品团购,超级便宜

一棵采用孩子兄弟表示法存储的树,设计算法,按层次依次输出该树的所有...
1.输出根 2.将根进队列保存,将指针移到该根的右孩子。3.指针不为空则重复1,2一直到指针为空 4.如果队列不为空,则出队列头,指针移到队列头的左孩子,重复1-4直到队列为空

编写一棵以孩子兄弟链表表示的树统计叶子节点的数目的算法
include <stdio.h> include <stdlib.h> typedef char ElemType;typedef struct BTNode{ ElemType data;struct BTNode* left;struct BTNode* right;}BTreeNode;BTreeNode *CreateBTree(BTreeNode * HL);void InOrder(BTreeNode *HL);int CountTreeLeaf(BTreeNode *HL);int main(){ BTreeNode *...

设树采用孩子兄弟表示法存放,用类C语言设计算法计算树的高度。
采用递归求解,先求左子树的高度和右子树的高度,然后整棵树的高度就是两颗子树高度的最大值+1。假定叶子节点高度为0。代码如下:struct node { int val; struct node* left; struct node* right;};int height(struct node* root){ int h, lh, rh; if ( root == NULL) ...

编写计算树中每一个结点的度,树用孩子-兄弟表示的二叉链表存储
Degree(T->nextsibling, d);} }

用孩子兄弟表示法建立的树如何求其各个节点的度
c.孩子兄弟链表法,这种方法更简单,孩子兄弟表示法又称二叉树表示法,即遍历该树,若该树节点中孩子域firstchild为空,则为叶结点。那么只要统计有多少个节点孩子域为空。2.孩子兄弟链表表示法,遍历树的方法:step1:先访问根节点;step2:若根节点有孩子则访问该节点的孩子,若没有则访问兄弟域节点;s...

数据结构用孩子兄弟表示法创建好了树之后运行程序的时候怎么输入树中的...
1.计算一般树的叶子节点很多种方法:a.若树是双亲表示法,其实就是个一维数组表示法,数组的元素有两个域数据域data和双亲位置域parent,每个元素对应一个数组下标。很明显双亲位置域存的就是数组下标,就可以查双亲位置域,双亲位置域出现过了的数组下标,不可能为叶结点,肯定就是没有出现过的就是叶...

编写算法,求以孩子-兄弟链表表示的树中的叶子结点个数
LeafCount_CSTree(CSTree T)\/\/求孩子兄弟链表表示的树T的叶子数目 { if(!T->firstchild) return 1; \/\/叶子结点 else { count=0;for(child=T->firstchild;child;child=child->nextsibling)count+=LeafCount_CSTree(child);return count; \/\/各子树的叶子数之和 } }\/\/LeafCount_CSTree ...

以孩子兄弟表示法存储求树的高度。要用递归和非递归方法。但是我不会...
其非递归算法使用队列,逐层遍历树,取得树的高度。int Height(CSTree bt) \/\/递归求以孩子兄弟链表表示的树的深度{int hc,hs; if (bt==null) return (0);elseif (!bt->firstchild) return (1+height(bt->nextsibling);\/\/子女空,查兄弟的深度else \/\/ 结点既有第一子女又有兄弟,高度取...

求高手帮忙,在采用孩子兄弟链表存储的树类tree中,增加以下操作: 返回...
treenode<T> * getchild(treenode<T>*p,int i){ treenode<T> *temp=p;for(int j=0;jchild==NULL) {cout<<"wrong input"<<endl; break;} temp=temp->child;} return temp;}

数据结构:树和森林
孩子兄弟表示法,也称为二叉树表示法,使用二叉链表作为树的存储结构。每个结点包含两个链域:firstchild域指向第一个孩子结点,nextsibling域指向下一个兄弟结点。这种表示法便于实现树的查找操作,如访问结点的第i个孩子。示例:以孩子兄弟表示法存储的树。森林与二叉树的转换规则如下:森林转换为二叉树时...

相似回答