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