二叉树遍历

今天讲的不是 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;
}
相关推荐
熬了夜的程序员36 分钟前
【华为机试】208. 实现 Trie (前缀树)
数据结构·算法·华为od·华为
数据智能老司机5 小时前
图算法趣味学——最短路径
数据结构·算法·云计算
gopher_looklook5 小时前
Go并发实战:singleflight 源码解读与二次封装
数据结构·后端·go
终焉代码6 小时前
【C++】STL二叉搜索树——map与set容器的基础结构
开发语言·数据结构·c++
无敌的大魔王8 小时前
数据结构 双链表与LinkedList
数据结构
啊阿狸不会拉杆9 小时前
《算法导论》第 15 章 - 动态规划
数据结构·c++·算法·排序算法·动态规划·代理模式
重生之我是Java开发战士13 小时前
【数据结构】深入理解顺序表与通讯录项目的实现
数据结构·算法
啊阿狸不会拉杆1 天前
《算法导论》第 14 章 - 数据结构的扩张
数据结构·c++·算法·排序算法
闪电麦坤951 天前
数据结构:栈(Stack)
数据结构
我今晚不熬夜1 天前
使用单调栈解决力扣第42题--接雨水
java·数据结构·算法·leetcode