数据结构——简单二叉树的性质和遍历

二叉树

两个值得注意的性质:

1.二叉树是有序树,这个我想了很久不知道为什么,可是为什么二叉树只有三种遍历方式,而不是六种?说明每个形态不同的树都有不同的含义。那完全二叉树和平衡二叉树呢?也是一样的

2.n0=n2+1 推法: n-1=2n2+n1 n=n0+n1+n2

遍历

前 中 后序遍历

cpp 复制代码
#include <iostream>
#include <stdlib.h>

using namespace std;

typedef struct Node
{
    struct Node *left;
    struct Node *right;
    int data;
} N, Tr;
N *createNode(int data)
{
    N *a = (N *)malloc(sizeof(N));
    a->left = a->right = NULL;
    a->data = data;
    return a;
}
void pre(Tr *root)
{
    if (root == NULL)
        return;
    cout
        << root->data << " ";
    pre(root->left);
    pre(root->right);
}
void In(Tr *root)
{
    if (root == NULL)
        return;
    In(root->left);
    cout << root->data << " ";
    In(root->right);
}
void aft(Tr *root)
{
    if (root == NULL)
        return;
    aft(root->left);
    aft(root->right);
    cout << root->data << " ";
}
int main()
{
    Tr *root = createNode(3);
    root->right = createNode(4);
    root->left = createNode(5);
    root->left->left = createNode(6);
    root->left->right = createNode(7);
    root->right->left = createNode(8);
    root->right->right = createNode(9);
    pre(root);
    cout << endl;
    In(root);
    cout << endl;
    aft(root);
    cout << endl;
}
相关推荐
AKDreamer_HeXY29 分钟前
QOJ 12255 - 36 Puzzle 题解
数据结构·c++·数学·算法·icpc·qoj
Rabitebla1 小时前
vector 的骨架:三根指针、模板陷阱与迭代器失效的第一现场
开发语言·数据结构·c++·算法
Sarvartha2 小时前
N 个字符串最长公共子序列(LCS)求解问题
数据结构·算法
m0_629494732 小时前
LeetCode 热题 100-----16.除了自身以外数组的乘积
数据结构·算法·leetcode
迷途之人不知返3 小时前
优先级队列:priority_queue
数据结构·c++
jieyucx3 小时前
Go 零基础数据结构:顺序表(像「排抽屉」一样学增删改查)
java·数据结构·golang
想唱rap3 小时前
应用层协议与序列化
linux·运维·服务器·网络·数据结构·c++·算法
jinyishu_3 小时前
链表经典OJ题
c语言·数据结构·算法·链表
澈2074 小时前
C++引用与指针:核心区别全解析
开发语言·数据结构·c++
迷途之人不知返4 小时前
deque的简单认识
数据结构·c++