二叉树的镜像
来源:互联网 发布:javlibrary新域名14 编辑:程序博客网 时间:2024/05/11 14:04
问题描述:请完成一个函数,输入一个二叉树,该函数输出它的镜像
二叉树定义如下:
struct BinaryTreeNode
{
int value;
BinaryTreeNode *left;
BinaryTreeNode *right;
};
这个问题很直观,一般很快就会有思路:要求树的镜像,我们先前序遍历这棵树的每个结点,如果遍历到的结点有子结点,就交换它的两个子结点。当交换完所有非叶子结点的左右结点之后,就得到了数的镜像。
参考代码如下:
void MirrorRecursively(BinaryTreeNode *pNode){ if((pNode == NULL) || (pNode->m_pLeft == NULL && pNode->m_pRight)) return; BinaryTreeNode *pTemp = pNode->m_pLeft; pNode->m_pLeft = pNode->m_pRight; pNode->m_pRight = pTemp; if(pNode->m_pLeft) MirrorRecursively(pNode->m_pLeft); if(pNode->m_pRight) MirrorRecursively(pNode->m_pRight); }
上面的代码是用递归实现的,看起来很直观,容易理解。下面我们用迭代的方法来实现,代码如下
void MirrorIteratively(BinaryTreeNode* pRoot){ if(pRoot == NULL) return; std::stack<BinaryTreeNode*> stackTreeNode; stackTreeNode.push(pRoot); while(stackTreeNode.size() > 0) { BinaryTreeNode *pNode = stackTreeNode.top(); stackTreeNode.pop(); BinaryTreeNode *pTemp = pNode->m_pLeft; pNode->m_pLeft = pNode->m_pRight; pNode->m_pRight = pTemp; if(pNode->m_pLeft) stackTreeNode.push(pNode->m_pLeft); if(pNode->m_pRight) stackTreeNode.push(pNode->m_pRight); }}
- 二叉树的镜像
- 二叉树的镜像
- 二叉树的镜像
- 二叉树的镜像
- 二叉树的镜像
- 二叉树的镜像
- 二叉树的镜像
- 二叉树的镜像
- 二叉树的镜像
- 二叉树的镜像
- 二叉树的镜像
- 二叉树的镜像
- 二叉树的镜像
- 二叉树的镜像
- 二叉树的镜像
- 二叉树的镜像
- 二叉树的镜像
- 二叉树的镜像
- 表单那点事
- Asp.net弹出窗口大全
- CMD 下打war 包
- linux命令ps aux|grep xxx详解
- 腐蚀,膨胀,opencv的形态学处理
- 二叉树的镜像
- uva 11038 How Many O's?
- MFC 文件打开对话框(CFileDialog类或OPENFILENAME结构体)后,保持程序的路径不变
- C/C++ new 一个二维数组
- JPA注解补充
- 操作系统开发——NASM集成开发环境设置 zz
- Linux进程的实际用户ID和有效用户ID
- 我的心情还是不错
- Linux 中 Shell 中的数组(将命令行参数作为数组的元素)