/**
搜索二叉树 中序遍历
完全二叉树 层次遍历
*/
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;
}
};