判断任意给定的二叉树是否为满二叉树

设二叉树采用二叉链表存储,试编写一个判断任意给定的二叉树是否为满二叉树的算法。

#include<stdio.h>

#include<stdlib.h>

typedef struct BiTnode  

{  

        int data;  

        struct BiTnode* Lchild,*Rchild;   

}BiTnode,*BiTree;  

  

void create(BiTree &S)  

{  

        char ch;  

        char temp;  

        scanf("%c",&ch);  

        temp=getchar();  

        if(ch=='#')  

        {  

                S=NULL;  

        }  

        else  

        {  

                S=(BiTree)malloc(sizeof(BiTnode) );  

                if(!S)  

                {  

                    exit(0);  

                }  

                else  

                {  

                        S->data=ch;  

                         

                        create(S->Lchild);  

                        

                        create(S->Rchild);  

                }  

  

        }  

        return;  

  

}

int full(BiTree S){

if(S->Lchild ==NULL&&S->Rchild ==NULL)

return 1;

else if(S->Lchild ==NULL||S->Rchild ==NULL)

return 0;

else

return 0;

}

int main()

{  

     BiTree S;

 printf("创建一个树\n");       

     create(S);   

     if(full(S))

     printf("满二叉树\n");

 else

     printf("不是满二叉树\n");

     return 0;

 }

  • 1
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值