二叉树遍历

今天讲的不是 leetcode 上的题,但也和二叉树有关,一道比较有意思的题

牛客网上的题,如果看懂了,也可以来试着做一下:

二叉树遍历_牛客题霸_牛客网 (nowcoder.com)


题目

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

输入描述:

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

文字 和 画图 分析

和之前的题不一样的一点,这道题难在如何构建二叉树

这里我们可以利用二叉树前序遍历的同时,将二叉树的左子树和右子树连接起来

以题例举例:

搭建过程:

需要注意的一点是,二叉树的搭建结束,最后连的一根线一定的空树,当前序走完后,其实这个字符串的字符已经全部拿完了,我们可以不需要通过字符是否到 '\0' ,来判断是否已经搭建好

已经连接好各个节点后,利用树再去中序遍历就很简单了


代码

cpp 复制代码
#include <stdio.h>
#include<stdlib.h>
typedef char TLtype;
typedef struct treelist
{
	 TLtype val;
	struct treelist* left;
	struct treelist* right;
}TL;
TL* creatnode(char x)
{
	TL* newnode = (TL*)malloc(sizeof(TL));
	newnode->val = x;
	return newnode;
}
TL* sertree(int *pi,char *pa)
{
    
        if(pa[*pi] == '#')
        {
            (*pi)++;
            return NULL;
        }
          TL* root = creatnode(pa[(*pi)++]);
           root->left = sertree(pi,pa);
           root->right = sertree(pi,pa);
           return root;
    return root;
}
void  Inorder(TL *root)
{
    if(root == NULL)
    {
        return;
    }
    Inorder(root->left);
    printf("%c ",root->val);
    Inorder(root->right);
}
int main()
{
    TL *plist = NULL;
    char ch[100];
    scanf("%s",ch);
    int i = 0;
    plist = sertree(&i,ch);
    Inorder(plist);
    return 0;
}
相关推荐
我星期八休息24 分钟前
IT疑难杂症诊疗室:AI时代工程师Superpowers进化论
linux·开发语言·数据结构·人工智能·python·散列表
漂流瓶jz40 分钟前
UVA-1152 和为0的4个值 题解答案代码 算法竞赛入门经典第二版
数据结构·算法·二分查找·题解·aoapc·算法竞赛入门经典·uva
你撅嘴真丑1 小时前
map 与 set容器的应用--话题焦点人物
数据结构
生成论实验室1 小时前
《事件关系阴阳博弈动力学:识势应势之道》第二篇:阴阳博弈——认知的动力学基础
数据结构·人工智能·科技·神经网络·算法
li1670902702 小时前
第二十七章:智能指针
c语言·数据结构·c++·visual studio
代码中介商4 小时前
数据结构开篇:从问题到解决方案
数据结构
AKDreamer_HeXY5 小时前
QOJ 12255 - 36 Puzzle 题解
数据结构·c++·数学·算法·icpc·qoj
Rabitebla5 小时前
vector 的骨架:三根指针、模板陷阱与迭代器失效的第一现场
开发语言·数据结构·c++·算法
Sarvartha6 小时前
N 个字符串最长公共子序列(LCS)求解问题
数据结构·算法
m0_629494736 小时前
LeetCode 热题 100-----16.除了自身以外数组的乘积
数据结构·算法·leetcode