面试题:二叉树

二叉树的高度

int BinaryTreeHeight(ListNode * node)
{
     if(node == NULL)
     {
          return 0;
     }
     
     LeftHeight = BinaryTreeHeight(node->left);
     RightHeight = BinaryTreeHeight(node->right);

     return LeftHeight>RightHeight?(LeftHeight+1):(RightHeight+1);
}

二叉树中和为某一值的路径

void FindAllPath(ListNode * head, int num)
{
     if(head == NULL)
     {
          return;
     }
     vector<ListNode *> v;
     int sum = 0;
     
     FindPath(head, v, sum, num);   
}

void FindPath(ListNode * head, vector<int> v, int sum, int num)
{
     sum  += head->data;
     v.push_back(head);

     bool isLeft = head->left == NULL && head->right ==NULL;
     if(isLeft && sum == num)
     {
          vector<int> ::iterator iter =v.begin();
          for(:iter != v.end();iter++)
          {
               print *tier;
          }
     }
     if(head->left != NULL)
     {
          FindPath(head->left, v, sum, num);
     }
     
     if(head->right != NULL)
     {
          FindPath(head->right, v, sum, num);
     }
     
     v.pop_back();
}

二叉树的子数

bool isSubTree(ListNode * head1, ListNode * head2)
{
     bool result = false;
     if(head1 != NULL && head2 != NULL)
     {
          if(head1->data == head2->data)
          {
               result = DoesTree1HaveTree2(head1,head2);
          }
          
          if(!result)
          {
               result = isSubTree(head1->left, head2);
          }

          if(!result)
          {
               result = isSubTree(head1->right, head2);
          }
     }
     return result;
}

bool DoesTree1HaveTree2(ListNode *head1, ListNode *head2)
{
     if(head2 == NULL)
     {
          return true;
     }
     
     if(head1 ->data != head2->data)
     {
          return false;
     }
     
   
     bool left_result = DoesTree1HaveTree2(head1->left, head2->left);
     bool right_result = DoesTree1HaveTree2(head1->right, head2->right);
     }
     if(left_result && right_result)
     {
          return true;
     }
     else
     {
          return false;
     }
}



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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值