对称二叉树
迭代法
class Solution { public: bool isSymmetric(TreeNode* root) { if(root == NULL) return true; queue<TreeNode*> que; que.push(root->left); // 将左子树头结点加入队列 que.push(root->right); // 将右子树头结点加入队列 while(!que.empty()){ TreeNode* leftNode = que.front(); que.pop(); //左节点出队 TreeNode* rightNode = que.front(); que.pop(); //右节点出队 if (!leftNode && !rightNode) { // 左节点为空、右节点为空,此时说明是对称的 continue; } // 左右一个节点不为空,或者都不为空但数值不相同,返回false if ((!leftNode || !rightNode || (leftNode->val != rightNode->val))) { return false; } que.push(leftNode->left); // 将左子结点加入队列 que.push(rightNode->right); // 将右子结点加入队列 que.push(leftNode->right); // 将左子结点加入队列 que.push(rightNode->left); // 将右子结点加入队列 } return true; } };
复习二叉树的用法
标签:结点,队列,Day33,rightNode,que,push,leftNode,LeetCode,刷题 From: https://www.cnblogs.com/tianmaster/p/16989548.html