基础知识html
每个节点最多有两棵子树,因此二叉树中不存在度大于2的节点,注意,是最多有两棵,没有也是能够的
左子树和右子树是有顺序的,次序不能颠倒,这点能够在哈夫曼编码中体现, 顺序不一样编码方式不一样编码
-即便树中某个节点中只有一个子树的花,也要区分它是左子树仍是右子树指针
二叉树通常有五种形态
1.空二叉树
2.只有一个根节点
3.根结点只有左子树
4.根节点只有右子树code
1:在二叉树的第i层上最多有2^i-1个节点
2:深度为K的二叉树之多有2^k-1个节点htm
这里的深度K意思就是有K层的二叉树
3:对于任何一棵二叉树T,若是其终端节点有No个,度为2的节点数有N2,则No=N2+1
4: 具备n个节点的彻底二叉树的深度为[log2n]+1([x]表示不大于x的最大整数)blog
//二叉树的存储结构,一个数据域,2个指针域 typedef struct BiTNode { char data; struct BiTNode *lchild,*rchild; }BiTNode,*BiTree;
//我在这里实现的是,二叉树的前序遍历方式建立,若是要使用中序或者后序的方式创建二叉树,只需将生成结点和构造左右子树的顺序改变便可 void CreateBiTree(BiTree *T) { char ch; scanf("%c",&ch); if(ch=='#') *T=NULL; else { *T=(BiTree )malloc(sizeof(BiTNode)); if(!*T) exit(-1); (*T)->data=ch; CreateBiTree(&(*T)->lchild); CreateBiTree(&(*T)->rchild); } }
void PreOrderTraverse(BiTree T)//二叉树的先序遍历 { if(T==NULL) return ; printf("%c ",T->data); PreOrderTraverse(T->lchild); PreOrderTraverse(T->rchild); } void InOrderTraverse(BiTree T)//二叉树的中序遍历 { if(T==NULL) return ; InOrderTraverse(T->lchild); printf("%c ",T->data); InOrderTraverse(T->rchild); } void PostOrderTraverse(BiTree T)//后序遍历 { if(T==NULL) return; PostOrderTraverse(T->lchild); PostOrderTraverse(T->rchild); printf("%c ",T->data); }
#include<stdio.h> #include<stdlib.h> typedef struct BiTNode { char data; struct BiTNode *lchild,*rchild; }BiTNode,*BiTree; void PreOrderTraverse(BiTree T)//二叉树的先序遍历 { if(T==NULL) return ; printf("%c ",T->data); PreOrderTraverse(T->lchild); PreOrderTraverse(T->rchild); } void InOrderTraverse(BiTree T)//二叉树的中序遍历 { if(T==NULL) return ; InOrderTraverse(T->lchild); printf("%C ",T->data); InOrderTraverse(T->rchild); } void PostOrderTraverse(BiTree T)//后序遍历 { if(T==NULL) return; PostOrderTraverse(T->lchild); PostOrderTraverse(T->rchild); printf("%c ",T->data); } void CreateBiTree(BiTree *T) { char ch; scanf("%c",&ch); if(ch=='#') *T=NULL; else { *T=(BiTree )malloc(sizeof(BiTNode)); if(!*T) exit(-1); (*T)->data=ch; CreateBiTree(&(*T)->lchild); CreateBiTree(&(*T)->rchild); } } void pri(){ printf("\n"); } int main() { BiTree T; printf("输入树(#表明空节点 AB#C##D##):"); CreateBiTree(&T); printf("前序遍历的结果是:"); PreOrderTraverse (T); printf("\n中序遍历的结果是:"); InOrderTraverse(T); printf("\n后序遍历的结果是:"); PostOrderTraverse(T); pri(); return 0; }