题解 | #判断一棵二叉树是否为搜索二叉树和完全二叉树#(中序遍历和层次遍历)

判断一棵二叉树是否为搜索二叉树和完全二叉树

http://www.nowcoder.com/practice/f31fc6d3caf24e7f8b4deb5cd9b5fa97

/**
搜索二叉树 中序遍历 
完全二叉树 层次遍历 
 */
class Solution {
public:
    TreeNode *pre = new TreeNode(-1000000);
    vector<bool> judgeIt(TreeNode* root) {
        bool f1, f2;
        f1 = judgef1(root);
        f2 = judgef2(root);
        return {f1,f2};
    } 
    // 中序遍历有序
    bool judgef1(TreeNode* root){
        if(!root) return true; // 结点为空返回true
        bool left = judgef1(root->left);  // 判断左子树是否有序
        bool cur = pre->val < root->val;  // 判断当前节点是否有序
        pre = root; // 按中序遍历,记录前一个指针
        bool right = judgef1(root->right); // 判断右子树是否有序
        return left&&right&&cur;
    }
    // 层次遍历 当第一次遇到空节点后发现非空节点,则非完全二叉树
    bool judgef2(TreeNode* root){
        if(!root)return true;
        bool f_empty = false; // 第一次碰到空节点,设为true,判断是否遇到非空节点
        queue<TreeNode *> q; 
        q.push(root);
        while(!q.empty()){
            TreeNode * tmp = q.front();
            q.pop();
            if(tmp->left) {
                if(f_empty) return false; // 遇到空节点,还遇到了非空节点返回false
                q.push(tmp->left);
            }
            else f_empty = true; // 标记遇到了非空节点
             if(tmp->right) {
                if(f_empty) return false; // 遇到空节点,还遇到了非空节点返回false
                q.push(tmp->right);
            }
            else f_empty = true; // 标记遇到了非空节点

        }
        return true;
    }
};
全部评论

相关推荐

压力很大,面试官全程高压,问的问题不难,但是没有任何反馈,很慌张,也无算法。实习问了20分钟,一直问我你们做的有什么用,总时长一小时1.学校都有什么课程2.spring的ioc原理以及优点3.除了解耦还知道什么?4.springboot与spring区别,二者的源码看过没?Tomcat了解嘛?有没有具体看过5.spring的bean,面试官一直在重复一个思想问我懂不懂,完全没听过6.mybatis是干什么的?ibatis用过没?平常怎么写SQL?完全不写嘛?7.设计一个分布式双十一秒杀系统(前端,网关,缓存,数据库防超卖全设计)8.怎么做限流9.缓存与数据库一致性,你做异步要用户等你嘛?10.负载均衡怎么做11.多数据中心还是单数据中心,如果出现没卖完怎么做(到这完全不会了,面试官直接说换个话题吧)12.平常读书吗?13.上过哲学课嘛?14.兴趣爱好有没有15.对ai的看法16.来深圳有问题嘛?17.为什么不考研18.上大学带给了你什么?你提升在哪里,有没有具体的例子?反问:1.现在手机都有应用市场,应用宝怎么盈利?除了手机应用市场还是有人用,现在在做跨端,微软都有合作,之后会进军mac,主要做游戏,腾讯本身就是游戏大户。2.面试表现?整体评价一下会给到反馈。面完直接变HR面,今天HR面后,已经转为录用评估了,来牛客许个愿,暑期现在还没什么面试,希望能拿个offer之后再考虑要不要留在手子吧。
nunuking:三面压力这么大吗,面试的会议约了多长时间呀
面试问题记录
点赞 评论 收藏
分享
03-10 11:23
门头沟学院 Java
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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