二叉树

二叉树的顺序存储

#include<stdio.h>

#include<stdlib.h>

typedef char ElemType;

#define max 16

typedef struct BinaryNode{

ElemType data[max];            //创建存储数组

int size;                      //数组的大小

}binarytree;

//初始化二叉树

void init(binarytree *T)

{

for (int i = 0; i < max; i++){

T->data[i] = NULL;         //将数组全部置为空并设置长度为0

}

T->size = 0;

}

//层次遍历创建二叉树

void creattree(binarytree *T)

{

ElemType n;

printf("当前为第%d个结点,请输入结点的值:", T->size);

n = getchar();

T->data[T->size] = n;

T->size++;

if (T->size == 20)

return;

if (n == '*')

return;

else{

n = getchar();          //吸收回车符

creattree(T);

}

}

//层次遍历打印

void Cprintftree(binarytree *T, int n)

{

for (; n<T->size; n++)

{

if (T->data[n] == NULL || T->data[n] == '*')

return;

else{

if (T->data[n] != '#')

printf("%c", T->data[n]);

}

}

}

//先序打印二叉树

void Rprintftree(binarytree *T, int n)

{

if (T->data[n] == NULL || T->data[n] == '*' || T->data[n] == '#')

return;

printf("%c", T->data[n]);

Rprintftree(T, 2 * n + 1);

Rprintftree(T, 2 * (n + 1));

}

//中序打印二叉树

void Zprintftree(binarytree *T, int n)

{

if (T->data[n] == NULL || T->data[n] == '*' || T->data[n] == '#')

return;

Zprintftree(T, 2 * n + 1);

printf("%c", T->data[n]);

Zprintftree(T, 2 * (n + 1));

}

//后序打印二叉树

void Hprintftree(binarytree *T, int n)

{

if (T->data[n] == NULL || T->data[n] == '*' || T->data[n] == '#')

return;

Hprintftree(T, 2 * n + 1);

Hprintftree(T, 2 * (n + 1));

printf("%c", T->data[n]);

}

//求结点数

int node(binarytree *T)

{

int num = 0;

for (int n = 0; n<T->size; n++)

{

if ((T->data[n] != NULL) && (T->data[n] != '#') && (T->data[n] != '*'))

{

num++;

}

}

return num;

}

//计算叶子结点数

int leaf(binarytree *T)

{

int num = 0;

for (int n = 0; n<T->size; n++)

{

if ((T->data[n] != NULL) && (T->data[n] != '#') && (T->data[n] != '*') && (T->data[2 * n + 1] == NULL) && (T->data[2 * (n + 1)] == NULL))

{

num++;

}

}

return num + 1;

}

int main()

{

binarytree T;

int n = 0;

init(&T);

printf("请从上到下从左往右输入结点的值,空结点用#代替当结束时用*,你最多可以输入%d个:\n", max);

creattree(&T);

printf("树得结点数为%d\n", node(&T));

printf("树得叶子结点数为%d\n", leaf(&T));

printf("树层次遍历结构的是:");

Cprintftree(&T, n);

printf("\n树先序遍历结构的是:");

Rprintftree(&T, n);

printf("\n树中序遍历结构的是:");

Zprintftree(&T, n);

printf("\n树后序遍历结构的是:");

Hprintftree(&T, n);

return 0;

}


二叉树的链式存储

#include<stdio.h>

#include<stdlib.h>

typedef int ElemType;

typedef struct BinaryTreeNode{

ElemType Date;

struct BinaryTreeNode *lChild, *rChild;

}BinaryTreeNode,*BiTree;

//先序遍历(PLR):依次访问根结点,左子树,右子树

void PreOrderTransverse(BiTree t)

{

if (t == NULL)

return;

printf("%c", t->Date); //打印输出根结点

PreOrderTransverse(t->lChild); //然后先序遍历左子树

PreOrderTransverse(t->rChild); //最后先序遍历右子树

}

//中序遍历(LPR):依次访问左子树,根结点,右子树

void InOrderTransverse(BiTree t)

{

if (t == NULL)

return;

InOrderTransverse(t->lChild); //中序遍历根结点的左子树

printf("%c", t->Date); //打印输出根结点

InOrderTransverse(t->rChild); //最后中序遍历右子树

}

//后序遍历(LRP):依次访问左子树,右子树,根结点

void PostOrderTransverse(BiTree t)

{

if (t == NULL)

return;

PostOrderTransverse(t->lChild); //后序遍历根结点的左子树

PostOrderTransverse(t->rChild); //然后后序遍历根结点的右子树

printf("%c", t->Date); //打印输出根结点

}

//先序遍历方法构建二叉树

BinaryTreeNode *PreCreateBt(BinaryTreeNode *t)

{

char ch;

ch = getchar();

if (ch == '#') //输入为#表示这里建立空二叉树,即遍历算法的空操作

t = NULL;

else

{

t = (BinaryTreeNode *)malloc(sizeof(BinaryTreeNode));

t->Date = ch; //构造根结点

t->lChild = PreCreateBt(t->lChild); //构造左子树

t->rChild = PreCreateBt(t->rChild); //构造右子树

}

return t;

}

//计算叶子数(度为0的结点)

int leaf(BiTree t)

{

int num1 = 0, num2 = 0;

if (t == NULL)

return 0;

if (t->lChild == NULL && t->rChild == NULL)

return 1;

else

{

num1++;

leaf(t->lChild);

num2++;

leaf(t->rChild);

}

return num1 + num2 + 1;

}

//结点数(树中的元素)

int node(BiTree t)

{

int num1, num2;

if (!t)

return 0;

if (t->lChild == NULL && t->rChild == NULL)

return 1;

else

{

num1 = node(t->lChild);

num2 = node(t->rChild);

}

return num1 + num2 + 1;

}

//复制二叉树

BiTree copy(BiTree t)

{

BiTree t1;

if (!t)

return NULL;

else

{

t1 = (BinaryTreeNode *)malloc(sizeof(BinaryTreeNode));

t1->Date = t->Date;

t1->lChild = t->lChild = copy(t->lChild);

t1->rChild = t->rChild = copy(t->rChild);

return t1;

}

}

//左右子树交换

void chage(BiTree t)

{

BiTree p;

if (!t)

return;

else

{

chage(t->lChild);

chage(t->rChild);

p = t->lChild;

t->lChild = t->rChild;

t->rChild = p;

}

}

int main()

{

BiTree t = NULL,t2;

printf("请输入树的数据:\n");

t = PreCreateBt(t);

printf("该树先序遍历:");

PreOrderTransverse(t);

printf("\n该树中序遍历:");

InOrderTransverse(t);

printf("\n该树后序遍历:");

PostOrderTransverse(t);

printf("\n");

printf("叶子数:%d\n", leaf(t));

printf("结点数:%d\n", node(t));

t2 = copy(t);

printf("复制树先序遍历:");

PreOrderTransverse(t2);

printf("\n左右子树交换后树的先序遍历");

chage(t);

PreOrderTransverse(t);

printf("\n");

}

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 199,636评论 5 468
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 83,890评论 2 376
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 146,680评论 0 330
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,766评论 1 271
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,665评论 5 359
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,045评论 1 276
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,515评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,182评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,334评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,274评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,319评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,002评论 3 315
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,599评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,675评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,917评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,309评论 2 345
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,885评论 2 341

推荐阅读更多精彩内容