データ構造---基本的な二分木インタビューの質問

1.LeetCode質問144-二分木のプレオーダートラバーサル

リンク:リンク
ここに画像の説明を挿入

/**
 * Definition for a binary tree node.
 * struct TreeNode {
 *     int val;
 *     struct TreeNode *left;
 *     struct TreeNode *right;
 * };
 */


/**
 * Note: The returned array must be malloced, assume caller calls free().
 */
 //因为你需要知道在开辟空间大小的时候,开辟多大才行,所以要算结点的个数
 int TreeSize(struct TreeNode* root)
 {
    
    
    if(root == NULL)
        return 0;
    else
        return 1+TreeSize(root->left) + TreeSize(root->right);
 }

//前序遍历
 void _preorderTraversal(struct TreeNode* root,int* array,int* pi)
 {
    
    
    if(root == NULL)
        return;
    array[(*pi)++] = root->val;
    _preorderTraversal(root->left,array,pi); //这里的pi是传过来的指针,可以直接的使用
    _preorderTraversal(root->right,array,pi);
 }

//这里值得注意的就是在传i的时候一定要传地址,因为只有传值才能做到在同一个i上++的效果
int* preorderTraversal(struct TreeNode* root, int* returnSize){
    
    
    int size = TreeSize(root);
    int* array = (int*)malloc(sizeof(int)*size);
    int i = 0;
    _preorderTraversal(root,array,&i); //思考题目就明白他需要你把结点的值都放在一个数组里面
    *returnSize = size;
    return array;
}

ここに画像の説明を挿入

2.LeetCode質問94-二分木の順序通りの走査

リンク:リンク

ここに画像の説明を挿入

/**
 * Definition for a binary tree node.
 * struct TreeNode {
 *     int val;
 *     struct TreeNode *left;
 *     struct TreeNode *right;
 * };
 */


/**
 * Note: The returned array must be malloced, assume caller calls free().
 */

 int TreeSize(struct TreeNode* root)
 {
    
    
    if(root == NULL)
        return 0;
    else
        return 1+TreeSize(root->left)+TreeSize(root->right);
 }
 
//左子树 根 右子树
 void _inorderTraversal(struct TreeNode* root,int* array,int* pi)
 {
    
    
    if(root == NULL)
        return;
    _inorderTraversal(root->left,array,pi);
    array[(*pi)++] = root->val;
    _inorderTraversal(root->right,array,pi);
 }

int* inorderTraversal(struct TreeNode* root, int* returnSize){
    
    
    int size = TreeSize(root);
    int* array = (int*)malloc(sizeof(int)*size);
    int i = 0;
    _inorderTraversal(root,array,&i);
    *returnSize = size;
    return array;
}

ここに画像の説明を挿入

3.LeetCode質問145-二分木のポストオーダートラバーサル

リンク:リンク
ここに画像の説明を挿入

/**
 * Definition for a binary tree node.
 * struct TreeNode {
 *     int val;
 *     struct TreeNode *left;
 *     struct TreeNode *right;
 * };
 */


/**
 * Note: The returned array must be malloced, assume caller calls free().
 */

  int TreeSize(struct TreeNode* root)
 {
    
    
    if(root == NULL)
        return 0;
    else
        return 1+TreeSize(root->left)+TreeSize(root->right);
 }

  void _postorderTraversal(struct TreeNode* root,int* array,int* pi)
 {
    
    
    if(root == NULL)
        return;
    _postorderTraversal(root->left,array,pi);
    _postorderTraversal(root->right,array,pi);
    array[(*pi)++] = root->val;
 }

int* postorderTraversal(struct TreeNode* root, int* returnSize){
    
    
    int size = TreeSize(root);
    int* array = (int*)malloc(sizeof(int)*size);
    int i = 0;
    _postorderTraversal(root,array,&i);
    *returnSize = size;
    return array;
}

ここに画像の説明を挿入

4.LeetCode質問965-単一値の二分木

リンク:リンク
ここに画像の説明を挿入

/**
 * Definition for a binary tree node.
 * struct TreeNode {
 *     int val;
 *     struct TreeNode *left;
 *     struct TreeNode *right;
 * };
 */

//分解为当前树 和左子树 右子树的子问题然后进行递归
bool isUnivalTree(struct TreeNode* root){
    
    
    if(root == NULL)
        return true;

    //检查当前树
    if(root->left && root->val != root->left->val)
        return false;
    if(root->right && root->val != root->right->val)
        return false;
        
    return isUnivalTree(root->left) && isUnivalTree(root->right);
}

ここに画像の説明を挿入

5.LeetCode質問104-二分木の最大深さ

リンク:リンク
ここに画像の説明を挿入

/**
 * Definition for a binary tree node.
 * struct TreeNode {
 *     int val;
 *     struct TreeNode *left;
 *     struct TreeNode *right;
 * };
 */


int maxDepth(struct TreeNode* root){
    
    
    if(root == NULL)
        return 0;
        //为的就是消除代码冗余
    int leftDepth = maxDepth(root->left);
    int rightDepth = maxDepth(root->right);

//求出左右子树较大的哪一个
    return leftDepth > rightDepth? leftDepth+1 :rightDepth+1;

}

ここに画像の説明を挿入

6.LeetCode問題226-バイナリツリーを反転する

リンク:リンク
ここに画像の説明を挿入
この問題を解決するには、次の2つの方法があります。①左右のサブツリーを反転してから、左側のサブツリーの左右のサブツリーと右側のサブツリーの左右のサブツリーを反転します。これは
ここに画像の説明を挿入
中位に相当します。トラバーサル

//接口要求返回的是树的根结点
struct TreeNode* invertTree(struct TreeNode* root){
    
    
    if(root == NULL)
    {
    
    
        return NULL;
    }
       else
    {
    
    
        struct TreeNode* tmp = root->left;
        root->left = root->right;
        root->right = tmp;

        invertTree(root->left);
        invertTree(root->right);
        return root;
    }
}


フォローアップトラバーサル同等で、左のサブツリーが最初にトラバースされ、右のサブツリーがトラバースされ、ルートが最後にトラバースされます。

struct TreeNode* invertTree(struct TreeNode* root){
    
    
    if(root == NULL)
    {
    
    
        return NULL;
    }
    else
    {
    
    
        struct TreeNode* right = root->right ;
        root->right = invertTree(root->left);
        //这里有一个覆盖值的问题,你把左边求出来直接链在了右边,那么右边原来的就没有了被覆盖了,你在转换就不对了
        root->left = invertTree(right);
        return root;
    }
}

ここに画像の説明を挿入

7.LeetCode質問100-同じツリー

リンク:リンク
ここに画像の説明を挿入

/**
 * Definition for a binary tree node.
 * struct TreeNode {
 *     int val;
 *     struct TreeNode *left;
 *     struct TreeNode *right;
 * };
 */

//把每一种情况都考虑到
bool isSameTree(struct TreeNode* p, struct TreeNode* q){
    
    
    if(p == NULL && q == NULL)
        return true;
    
    //结构不同
    if(p != NULL && q == NULL)
        return false;
    if(p == NULL && q != NULL)
        return false;
    
    //走到这里的时候就可以确定此时p和q都是不为空的,再来判断他们的值是否相同
    if(p->val != q->val) //此时==并不能判断出来结果,不能说他们一开始给的两个结点相同就直接返回true
        return false;

    
    
    return isSameTree(p->left,q->left) && isSameTree(p->right,q->right);
 
}

ここに画像の説明を挿入

8.LeetCode質問572-別のツリーのサブツリー

リンク:リンク。この
ここに画像の説明を挿入
質問では、前の質問のインターフェースを使用する必要があります。これにより、解決が容易になります。
tとsの各サブツリーを比較し、それらが同じである場合は、

/**
 * Definition for a binary tree node.
 * struct TreeNode {
 *     int val;
 *     struct TreeNode *left;
 *     struct TreeNode *right;
 * };
 */
  bool isSameTree(struct TreeNode* p, struct TreeNode* q);
 bool isSameTree(struct TreeNode* p, struct TreeNode* q){
    
    
    if(p == NULL && q == NULL)
        return true;
    
    //结构不同
    if(p != NULL && q == NULL)
        return false;
    if(p == NULL && q != NULL)
        return false;
    
    //走到这里的时候就可以确定此时p和q都是不为空的,再来判断他们的值是否相同
    if(p->val != q->val) //此时==并不能判断出来结果,不能说他们一开始给的两个结点相同就直接返回true
        return false;

    
    
    return isSameTree(p->left,q->left) && isSameTree(p->right,q->right);
 
}

//t是s完全相同的一部分(包括叶子)
//子树就是和你的一个子树相不相同
//让t和s中的每一颗子树都进行比较,如果有相同,则满足
bool isSubtree(struct TreeNode* s, struct TreeNode* t){
    
    
    if(s == NULL)
        return false;
    
    if(isSameTree(s,t))
        return true;
    
    //此时我需要让我的t去和我的s中的每一结点所在的子树都去比较
    return  isSubtree(s->left,t) || isSubtree(s->right,t);
}

ここに画像の説明を挿入

9.ソードフィンガーオファーアイテム28-対称二分木

リンク:リンクツリーが対称であるかどうか
ここに画像の説明を挿入
判断するには、最初に左右の子が対称で等しいかどうかを判断する必要があります。また、左側の子の左側のサブツリーが右側の子の右側のサブツリーと対称であるかどうかを判断する必要があります。 、および左の子の右のサブツリーが右の子の左の子と同じであるかどうか。サブツリーは対称です。


bool _isSymmetric(struct TreeNode* left, struct TreeNode* right)
{
    
    
    //这两种if情况判断的都是结构上面的不同
    if(left == NULL && right == NULL)
        return true;
    if(left == NULL || right == NULL)
        return false;
    return left->val == right->val
        && _isSymmetric(left->left, right->right)
        && _isSymmetric(left->right, right->left);
}
 
bool isSymmetric(struct TreeNode* root){
    
    
    if(root == NULL)
        return true;
    return _isSymmetric(root->left, root->right);
}

ここに画像の説明を挿入

おすすめ

転載: blog.csdn.net/MEANSWER/article/details/112752782