题解 | #二叉搜索树#

二叉搜索树

https://www.nowcoder.com/practice/3d6dd9a58d5246f29f71683346bb8f1b

#include <iostream>
#include <string>
using namespace std;

struct TreeNode {
    char data; //这里为什么要设置成char呢 -> 为了在遍历中能进行拼接
    TreeNode* leftChild;
    TreeNode* rightChild;
};

/**
 * 先序遍历
 * @param root
 * @return 返回先序遍历的字符串
 */
string PreOrder(TreeNode* root) {
    if (root == NULL) {
        return "";
    }
    return root->data + PreOrder(root->leftChild) +  PreOrder(root->rightChild);
}

/**
 * 中序遍历
 * @param root
 * @return 返回中序遍历的字符串
 */
string InOrder(TreeNode* root) {
    if (root == NULL) {
        return "";
    }
    return InOrder(root->leftChild) + root->data + InOrder(root->rightChild);
}

/**
 * 二叉搜索树的插入
 * @param root 根结点
 * @param data 数据
 */
void insertBST(TreeNode*& root, char data) {
    TreeNode* treeNode = new TreeNode;
    treeNode->data = data;
    treeNode->rightChild = NULL;
    treeNode->leftChild = NULL;
    if (root == NULL) { //初始树为空
        root = treeNode;
    } else { //往左边或者右边搜索
        TreeNode* curNode = root;
        TreeNode* preNode = root;
        while (true) {
            int curData = curNode->data;
            if (curData > data) { //往左走
                curNode = preNode->leftChild;
                if (curNode == NULL) { //走到最底部了
                    preNode->leftChild = treeNode;
                    break;
                } else { //继续往下走
                    preNode = curNode;
                }
            } else { //往右走
                curNode = preNode->rightChild;
                if (curNode == NULL) { //走到最底部了
                    preNode->rightChild = treeNode;
                    break;
                } else { //继续往下走
                    preNode = curNode;
                }
            }
        }
    }
}

int main() {
    int n;
    while (scanf("%d", &n) != EOF) {
        char seq[20];
        if (n == 0) { //输入0则退出
            break;
        }
        scanf("%s", seq); //输入初始树
        TreeNode* root1 = NULL;
        for (int i = 0; seq[i] != '\0'; i++) {
            insertBST(root1, seq[i]);
        }
        string inOrder1 = InOrder(root1);
        string preOrder1 = PreOrder(root1);
	  
        char str2[100];
        for (int i = 0; i < n; i++) {
            scanf("%s", str2);
            TreeNode* root2 = NULL;
            for (int j = 0; str2[j] != '\0'; j++) {
                insertBST(root2, str2[j]);
            }
            string preOrder2 = PreOrder(root2);
            string inOrder2 = InOrder(root2);
            if (inOrder1 == inOrder2 && preOrder1 == preOrder2) {
                printf("YES\n");
            } else {
                printf("NO\n");
            }
        }
    }
}

初始化root的时候一定要赋值为空!!!!!不然都不知道错在哪里,运行也不会出错。

这题的关键思路就是判断两个树的先序+中序是否相同,相同则是同一棵树

数的data要设置成data这才才好拼接

全部评论

相关推荐

02-01 12:05
复旦大学 Java
腾讯的提前批大概率应该是没有笔试的,但是这个时候有相当部分的同学简历估计都没有准备好,没准备好的同学也不用急,大部分都是3月之后开,这个时候开的绝大多数都是神仙打架,问的东西也比较难,打算投递的同学也多看下计算机网络和操作系统,腾讯对这部分的知识问的比较多。另外多刷下牛客的热门题库,刷题注意刷ACM模式,和牛客的周赛题,腾讯有的部门会从这里面出原题。我是@程序员花海关注我,带你了解更多校招资讯!
程序员花海:还没有来得及准备的同学可以看下学习路线:https://www.nowcoder.com/discuss/824693499982315520?sourceSSR=users算法题:https://www.nowcoder.com/feed/main/detail/20e7a999fa04485b88340a274411ca0d?sourceSSR=users八股文:https://www.nowcoder.com/discuss/833102362771251200?sourceSSR=users简历书写方式:https://www.nowcoder.com/discuss/839907820706205696?sourceSSR=users都是以前在牛客发的文章~
AI求职实录
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务