二叉树第K层节点个数 -- 采用递归和非递归方法

本文探讨如何计算二叉树的第K层节点数量,通过深入分析递归和非递归两种算法实现方式,详细解释每种方法的步骤和逻辑,帮助读者理解二叉树的层次遍历问题。
摘要由CSDN通过智能技术生成
/*二叉树第k层节点个数 -- 采用递归和非递归方法
经调试可运行源码及分析如下:
***/
#include <stdlib.h>
#include <iostream>
#include <queue>

using std::cout;
using std::cin;
using std::endl;
using std::queue;

/*二叉树结点定义*/
typedef struct BTreeNode
{
    char elem;
    struct BTreeNode *pleft;
    struct BTreeNode *pright;
}BTreeNode;

/*
求二叉树第k层的节点数
递归方式步骤:
给定根节点proot:
如果proot为空,或者层数k_Level <= 0,则为空树或者不合要求,则返回0;
如果proot不为空,且此时层数 k_Level==1,则此时proot为第K层节点之一,则返回1;
如果proot不为空,且此时层数 k_Level > 1,
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值