二叉树的三种遍历
创始人
2024-06-01 20:05:59
0

二叉树的遍历可以有:先序遍历、中序遍历、后序遍历

先序遍历:根、左子树,右子树

中序遍历:左子树、根、右子树

后序遍历:左子树、右子树、根

下面是我画图理解三种遍历:

二叉树里都是分为左子树和右子树。分治思想:1 将任务分给2 和 4 ,2又分给 3 和NULL,3又分给 NULL NULL 同样:4将任务分给 5 和6 ,5又分给NULL NULL ,6也是分给NULL NULL;

以上就是二叉树的三种遍历方法

void PrevOrder(BTNode* root)//先序遍历
{if(root->data == NULL){printf("NULL");return;}printf("%d",root->data);PrevOrder(root->left);//不为空,就分为左子树和右子树PrevOrder(root->right);//
}

下面是我画的递归图:

二、下面是实现二叉树的一些计算:

先手动创建和连接结点,使他成为二叉树。然后用代码实现,先序遍历、中序遍历、后序遍历。

typedef int BTDateType;
typedef struct BinaryTreeNode
{BTDateType data;struct BinaryTreeNode* left;struct BinaryTreeNode* right;
}BTNode;BTNode* BuyBTNode(BTDateType data)
{BTNode* node = (BTNode*)malloc(sizeof(BTNode));if (node == NULL){perror("malloc error");return;}node->data = data;node->left = node->right = NULL;return node;
}

这是随便手动连接的结点,以便于我们测试

接着我们可以写遍历顺序

//先序遍历
void PrevOder(BTNode* root)
{if (root == NULL){printf("NULL ");return;}printf("%d ", root->data);PrevOder(root->left);PrevOder(root->right);
}//中序遍历
void InOrder(BTNode* root)
{if (root == NULL){printf("NULL ");return;}InOrder(root->left);printf("%d ", root->data);InOrder(root->right);
}//后序遍历
void PastOrder(BTNode* root)
{if (root == NULL){printf("NULL ");return;}PastOrder(root->left);PastOrder(root->right);printf("%d ", root->data);
}

从上可以看出,结果和我们上面自己写的一样;

我们将遍历函数写完后,接着就算结点的数目:

//求结点数目
int TreeSize1(BTNode* root)
{if (root == NULL){return 0;}size++;//全局变量TreeSize1(root->left);TreeSize1(root->right);
}
//求节点数目
int TreeSize2(BTNode* root)
{return root == NULL ? 0 :TreeSize2(root->left) + TreeSize2(root->right) + 1;//+1是加根节点自己
}

求结点数,也是分治思想:

从根结点开始,最后结点需要汇总到根节点。要想知道,自己结点下还有多少结点,可以向自己的孩子得到;

三、求二叉树的高度/深度

我以空树的高度为0;

同样是分治思想:

//int TreeHeight(BTNode* root)
//{
//    if (root == NULL)
//    {
//        return 0;
//    }
//    //这一种会造成很大的资源浪费
//    return TreeHeight(root->left) > TreeHeight(root->right) ? TreeHeight(root->left)+1 :
//        TreeHeight(root->right)+1;
//}int TreeHeight(BTNode* root)
{if (root == NULL){return 0;}int leftHeight = TreeHeight(root->left); int rightHeight = TreeHeight(root->right);return leftHeight > rightHeight ? leftHeight + 1 :rightHeight + 1;
}

二叉树的深度大概就是这样

相关内容

热门资讯

通达信如何看美元指数 通达信如何看美元指数一、先查看公式公式名称:CYQKL公式描述:博弈K线长度公式具体:KL:100*...
都说土豆不是蔬菜,如果用土豆代... 都说土豆不是蔬菜,如果用土豆代替米饭做主食能减肥吗?都说土豆不是蔬菜,如果用土豆代替米饭做主食的话,...
有些事情我只猜对了前面结局却没... 有些事情我只猜对了前面结局却没有猜到是什么意思 ?那是你没有看清,跟你打个比方吧!好理解,比如一个人...
郑州荥阳市一小区被外卖骑手“孤... 郑州荥阳市一小区被外卖骑手“孤立”,外卖小哥与业主之间产生了哪些矛盾?肯定是由于外卖小哥的服务态度不...
考古 探险 考古 探险江苏镇江附近有什么适合的地方吗wu````````````````
浓浓药香里 和美乡村入画来 转自:河北新闻网全国文明村镇安国市北段村乡瓦子里村——浓浓药香里 和美乡村入画来游客畅游药博园花海。...
4400mAh:三星 Gala...   炒股就看金麒麟分析师研报,权威,专业,及时,全面,助您挖掘潜力主题机会! IT之家 7 月 1...
人工智能领域国际(地区)合作研... 转自:钦州发布原标题:人工智能领域国际(地区)合作研究与交流合作项目研讨会在钦举行钱锋作主题报告 刘...
近200名实习生转正!上海迪士... 转自:上观新闻毕业季的华特迪士尼大剧院里,近200名毕业生接过了特殊的“毕业证书”——他们从上海迪士...
第一观察|“多样文明是世界的本... 转自:北京日报客户端“多样文明是世界的本色。”7月10日,习近平主席在致全球文明对话部长级会议的贺信...