首页 > ACM题库 > 九度OJ > 九度-1184-二叉树遍历[解题代码]
2013
12-13

九度-1184-二叉树遍历[解题代码]

题目来源:2002年华中科技大学计算机研究生机试真题

题目描述:

编一个程序,读入用户输入的一串先序遍历字符串,根据此字符串建立一个二叉树(以指针方式存储)。
例如如下的先序遍历字符串:
ABC##DE#G##F###
其中“#”表示的是空格,空格字符代表空树。建立起此二叉树以后,再对二叉树进行中序遍历,输出遍历结果。

输入:

输入包括1行字符串,长度不超过100。

输出:

可能有多组测试数据,对于每组数据,
输出将输入字符串建立二叉树后中序遍历的序列,每个字符后面都有一个空格。
每个输出结果占一行。

样例输入:
abc##de#g##f###
样例输出:
c b e g d f a 

cpp 代码如下:
#include <stdio.h>
#include <stdlib.h>

char cache[101];

typedef struct Node
{
    char data;
    struct Node * lchild,* rchild;
};
struct Node * root;
int cnt;

struct Node * Build_tree()
{
    struct Node * root;
    if(cache[cnt++] == '#') root = NULL;
    else
    {
        root = (struct Node *)malloc(sizeof(struct Node));
        root -> data = cache[cnt - 1];
        root -> lchild = Build_tree();
        root -> rchild = Build_tree();
    }
    return root;
}
void in_order(struct Node *root)
{
    if(root != NULL)
    {
        in_order(root -> lchild);
        printf("%c ",root -> data);
        in_order(root -> rchild);
    }
}
void clean(struct Node *root)
{
    if(root != NULL)
    {
        clean(root -> lchild);
        clean(root -> rchild);
        free(root);
    }
}
int main()
{
    int i;
    while(scanf("%s",cache) != EOF)
    {
        cnt = 0;
        root = Build_tree();
        in_order(root);
        clean(root);
        printf("\n");
    }
    return 0;
}

/**************************************************************
	Problem: 1184
	User: coder
	Language: C
	Result: Accepted
	Time:10 ms
	Memory:904 kb
****************************************************************/


  1. “可以发现,树将是满二叉树,”这句话不对吧,构造的树应该是“完全二叉树”,而非“满二叉树”。

  2. “再把所有不和该节点相邻的节点着相同的颜色”,程序中没有进行不和该节点相邻的其他节点是否相邻进行判断。再说求出来的也不一样是颜色数最少的

  3. 其实国内大部分公司对算法都不够重视。特别是中小型公司老板根本都不懂技术,也不懂什么是算法,从而也不要求程序员懂什么算法,做程序从来不考虑性能问题,只要页面能显示出来就是好程序,这是国内的现状,很无奈。

  4. 有两个重复的话结果是正确的,但解法不够严谨,后面重复的覆盖掉前面的,由于题目数据限制也比较严,所以能提交通过。已更新算法