我是靠谱客的博主 有魅力店员,最近开发中收集的这篇文章主要介绍数据结构(树)算法设计题,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

数据结构(树)算法设计题

以二叉链表作为二叉树的存储结构,编写以下算法:

(1)统计二叉树的叶结点个数。
(2)判别两棵树是否相等。
(3)交换二叉树每个结点的左孩子和右孩子。

实现参考代码:(1)

int LeafNodeCount(BiTree T)

{

if(T==NULL)

return 0; //如果是空树,则叶子结点个数为0

else if(T->lchild==NULL&&T->rchild==NULL)

return 1; //判断结点是否是叶子结点(左孩子右孩子都为空),若是则返回1

else

return LeafNodeCount(T->lchild)+LeafNodeCount(T->rchild);

}

实现参考代码:(2)

int compareTree(TreeNode* tree1, TreeNode* tree2)

//用分治的方法做,比较当前根,然后比较左子树和右子树

{bool tree1IsNull = (tree1==NULL);

bool tree2IsNull = (tree2==NULL);

if(tree1IsNull != tree2IsNull)

{

return 1;

}

if(tree1IsNull && tree2IsNull)

{//如果两个都是NULL,则相等

return 0;

}//如果根节点不相等,直接返回不相等,否则的话,看看他们孩子相等不相等

if(tree1->c != tree2->c)

{

 return 1;

}

return (compareTree(tree1->left,tree2->left)&compareTree(tree1->right,tree2->right));}

实现参考代码:(3)

void ChangeLR(BiTree &T)

{

BiTree temp;

if(T->lchild==NULL&&T->rchild==NULL)

return;

else

{

temp = T->lchild;

T->lchild = T->rchild;

T->rchild = temp;

}//交换左右孩子

ChangeLR(T->lchild);  //递归交换左子树

ChangeLR(T->rchild);  //递归交换右子树

}

最后

以上就是有魅力店员为你收集整理的数据结构(树)算法设计题的全部内容,希望文章能够帮你解决数据结构(树)算法设计题所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(38)

评论列表共有 0 条评论

立即
投稿
返回
顶部