首页 > 代码库 > 二叉树学习——简单入门题
二叉树学习——简单入门题
入门题一:
输入一颗二叉树,你的任务是按从上到下、从左到右的顺序输出各个节点的值。每个节点都按照从根节点到它的移动序列给出
(L表示左,R表示右)。在输入中,每个节点的左括号和右括号之间没有空格,相邻节点之间用一个空格隔开。每颗树的输入用一
对空括号()结束(这对空括号不代表节点)
注意,如果从根到某个叶节点的路径上有的节点没有在输入中给出,或者给出了超出一次,应到输出 -1 。节点个数不超过256。
样例输入:
(11,LL) (7,LLL) (8,R) (5,) (4,L) (13,RL) (2,LLR) (1,RRR) (4,RR) ()
(3,L) (4,R) ()
样例输出:
5 4 8 11 13 4 7 2 1
0
#include "stdio.h" #include "stdlib.h" #include "string.h" #define maxn 256 char buf[maxn]; //保存读入节点 int failed; int n=0,ans[maxn]; //节点个数和输出序列 typedef struct Tnode{ int have_value; //是有赋过值 int v; //节点值 struct Tnode *left,*right; }Node; Node *root; //二叉树的根节点 Node* newnode() { Node *tmp=(Node*)malloc(sizeof(Node)); if(tmp!=NULL) { tmp->have_value=http://www.mamicode.com/0; //显示的初始化为0,因为malloc申请内存时并不把它清零>
入门题二:
输入一颗二叉树的先序遍历和中序遍历,输出它的后序遍历序列。
样例输入:
DBACEGF ABCDEFG
BCAD CBAD
样例输出:
ACBFGED
CDAB#include "stdio.h" #include "string.h" #define maxn 20 char preorder[maxn],inorder[maxn],postOrder[maxn]; //先序、中序 和后序 //n树的节点个数,pre前序,in中序,post后序 void build(int n,char *pre,char *in,char *post) { if(n<=0) return; int x=strchr(in,pre[0])-in; //找到根节点在中序遍历中的位置 build(x,pre+1,in,post); //递归构造左子树的后序遍历 build(n-x-1,pre+x+1,in+x+1,post+x); //递归构造右子树的后序遍历 post[n-1]=pre[0]; //根节点添加到最后 } int main() { while(scanf("%s%s",preorder,inorder)==2) { int n=strlen(preorder); build(n,preorder,inorder,postOrder); postOrder[n]=‘\0‘; printf("%s\n",postOrder); } return 0; }二叉树学习——简单入门题
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。