94.png

    1. /*
    2. 利用二叉树遍历的思想编写一个判断二叉树是否是二叉平衡树的算法
    3. 分析:
    4. 我们可以采取后序遍历来完成该算法,因为后序遍历不会含有重复计算。
    5. 我们对每一个节点进行判断,如果左右子树均平衡且左右子树高度差小于等于1,则该节点平衡
    6. */
    7. struct Tree {
    8. int data;
    9. Tree *left, *right;
    10. };
    11. #define _CRT_SECURE_NO_WARNINGS
    12. #include <stdio.h>
    13. #include <stdlib.h>
    14. Tree *create(Tree *T) {//先序创建一颗二叉树
    15. int data;
    16. printf("请输入当前节点值:data=");
    17. scanf("%d", &data);
    18. getchar();
    19. if (data != -1) {
    20. T = (Tree *)malloc(sizeof(Tree));
    21. T->data = data;
    22. T->left = NULL;
    23. T->right = NULL;
    24. T->left = create(T->left);
    25. T->right = create(T->right);
    26. }
    27. return T;
    28. }
    29. bool isAVL(Tree *T, int *depth) {
    30. if (!T) {//空节点,为平衡二叉树
    31. *depth = 0;
    32. return true;
    33. }
    34. int left = 0, right = 0;
    35. if (isAVL(T->left, &left) && isAVL(T->right, &right)) {//判断左右子树是否为平衡二叉树
    36. int diff = left - right;//左右子树的高度差
    37. if (abs(diff) <= 1) {//满足小于等于1,那就是平衡二叉树
    38. *depth = (1 + (left > right ? left : right));
    39. return true;
    40. }
    41. }
    42. return false;//前面一直未返回true,那就不是平衡二叉树
    43. }
    44. int main() {
    45. Tree *T = (Tree *)malloc(sizeof(Tree *));
    46. T = create(T);//创建一颗二叉树
    47. int depth = 0;
    48. isAVL(T, &depth) ? printf("是二叉平衡树"):printf("不是二叉平衡树");
    49. return 0;
    50. }