树倒着打印输出

思路

先向右遍历,同时空格也要变多,那么就先prt(root->right,space+cnt) 其中space是离最左边多远,cnt是每次叠加的有多远

输出最右边端点 和 空行

再向左遍历

同样prt(root->left,space+cnt)

代码

cpp 复制代码
#include <iostream>
#include <stack>
using namespace std;

typedef struct Node
{
    struct Node *left;
    struct Node *right;
    char data;
} N, *Tr;

void create(Tr *t)
{
    char ch;
    ch = getchar();
    if (ch == '.')
    {
        *t = NULL;
    }
    else
    {
        *t = (N *)malloc(sizeof(N));
        (*t)->data = ch;
        create(&(*t)->left);
        create(&(*t)->right);
    }
}
void printSpace(int num)
{
    for (int i = 0; i < num; i++)
    {
        cout << " ";
    }
}
void prt(Tr root, int space)
{
    if (root == NULL)
        return;
    int cnt = 1;
    prt(root->right, space + cnt);
    printSpace(space);
    cout << root->data << endl;
    prt(root->left, space + cnt);
}
int main()
{
    Tr Tree;
    create(&Tree);
    prt(Tree, 1);
    return 0;
}
相关推荐
sali-tec2 分钟前
C# 基于OpenCv的视觉工作流-章37-区域截图
图像处理·人工智能·opencv·算法·计算机视觉
DeepModel3 分钟前
【概率分布】正态分布(高斯分布)原理、可视化与机器学习实战
python·算法·概率论
啊哦呃咦唔鱼4 分钟前
LeetCode hot100-239 滑动窗口最大值
数据结构·算法·leetcode
m0_7432974214 分钟前
嵌入式LinuxC++开发
开发语言·c++·算法
2301_8008951014 分钟前
求最小生成树kruskal还是prim--备战蓝桥杯版h
算法
小小怪75017 分钟前
高性能密码学库
开发语言·c++·算法
Book思议-19 分钟前
【数据结构实战】 C 语言单链表通关:初始化 / 头插 / 尾插 / 增删改查全实现(附图解、可运行完整代码)
c语言·数据结构·算法
2301_8217005320 分钟前
模板代码生成工具
开发语言·c++·算法
wuhen_n24 分钟前
回溯算法入门 - LeetCode经典回溯算法题
前端·javascript·算法
宵时待雨26 分钟前
C++笔记归纳12:二叉搜索树
开发语言·数据结构·c++·笔记·算法