二叉树遍历

今天讲的不是 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;
}
相关推荐
蒙奇D索大19 分钟前
【数据结构】考研408 | 平方探测法精讲:跳跃探查的艺术与聚集迷思
数据结构·笔记·考研·改行学it
无限进步_1 小时前
【C语言】队列(Queue)数据结构的实现与分析
c语言·开发语言·数据结构·c++·算法·链表·visual studio
重生之我是Java开发战士2 小时前
【算法日记】排序算法:原理、实现、性能与应用
数据结构·算法·排序算法
zz0723202 小时前
数据结构 —— 字典树
数据结构
液态不合群3 小时前
查找算法详解
java·数据结构·算法
LYFlied3 小时前
【每日算法】LeetCode 105. 从前序与中序遍历序列构造二叉树
数据结构·算法·leetcode·面试·职场和发展
重生之我是Java开发战士3 小时前
【数据结构】Java对象的比较
java·jvm·数据结构
历程里程碑3 小时前
C++ 16:C++11新特化
c语言·开发语言·数据结构·c++·经验分享
_dindong3 小时前
算法杂谈:回溯路线
数据结构·算法·动态规划·bfs·宽度优先
DanyHope4 小时前
LeetCode 283. 移动零:双指针双解法(原地交换 + 覆盖补零)全解析
数据结构·算法·leetcode