输入前序遍历和中序遍历输出后序遍历——在构树和不构树两种情况下输出结果
来源:互联网 发布:单片机晶振不起振 编辑:程序博客网 时间:2024/06/15 15:09
#include<iostream>
using namespace std;
struct BinaryTreeNode
{
int m_nvalue;
BinaryTreeNode *m_pLeft;
BinaryTreeNode *m_pRigt;
};
BinaryTreeNode* ConstructCore(int *startpreorder, int *endpreorder, int *startinorder, int *endinorder)
{
//if (startpreorder == endpreorder)
//return startpreorder;
BinaryTreeNode *p = new BinaryTreeNode;
p->m_nvalue = startpreorder[0];
p->m_pLeft = NULL;
p->m_pRigt = NULL;
if (startpreorder == endpreorder)
return p;
int i = 0;
while (1)
{
if (startpreorder[0] == startinorder[i])
break;
else
++i;
/*if (i >= endpreorder - startpreorder + 1)
{
cout << "输入错误无法建立二叉树!" << endl;
return NULL;
}*/
}
if (i > 0)
p->m_pLeft = ConstructCore(startpreorder + 1, startpreorder + i, startinorder, startinorder + i-1);
if (i < endpreorder - startpreorder)
p->m_pRigt = ConstructCore(startpreorder + i + 1, endpreorder, startinorder + i + 1, endinorder);
return p;
}
BinaryTreeNode* Construct(int *preorder, int *inorder, int length)
{
if (preorder == NULL || inorder == NULL || length <= 0)
return NULL;
return ConstructCore(preorder, preorder + length - 1, inorder, inorder + length - 1);
}
//后序遍历打印二叉树
void LastCout(BinaryTreeNode *root)
{
if (root == NULL)
return;
LastCout(root->m_pLeft);
LastCout(root->m_pRigt);
cout << root->m_nvalue << " ";
}
void ACore(int *startpreorder, int *endpreorder, int *startinorder, int *endinorder)
{
if (startpreorder == endpreorder)
{
cout << startinorder[0] << " ";
return;
}
int i = 0;
while (1)
{
if (startpreorder[0] == startinorder[i])
break;
else
++i;
}
if (i > 0)
ACore(startpreorder + 1, startpreorder + i, startinorder, startinorder + i - 1);
if (i < endpreorder - startpreorder)
ACore(startpreorder + i + 1, endpreorder, startinorder + i + 1, endinorder);
cout << startpreorder[0] << " ";
}
// 输入前序遍历和中序遍历 输出后序遍历(前提 数组中数不能相等)
void A(int *preorder, int *inorder, int length)
{
if (preorder == NULL || inorder == NULL || length <= 0)
return;
else
ACore(preorder, preorder + length - 1, inorder, inorder + length - 1);
}
int main()
{
int preorder[] = { 1, 2, 4, 5, 6, 7, 3 };
int inorder[] = { 4, 2, 6, 5, 7, 1, 3 };
const int length = sizeof(preorder) / sizeof(preorder[0]);
BinaryTreeNode *p = Construct(preorder, inorder, length); //先构树 再输出后序遍历
LastCout(p);
cout << endl;
A(preorder, inorder, length); //直接输出后序遍历
cout << endl;
return 0;
}
using namespace std;
struct BinaryTreeNode
{
int m_nvalue;
BinaryTreeNode *m_pLeft;
BinaryTreeNode *m_pRigt;
};
BinaryTreeNode* ConstructCore(int *startpreorder, int *endpreorder, int *startinorder, int *endinorder)
{
//if (startpreorder == endpreorder)
//return startpreorder;
BinaryTreeNode *p = new BinaryTreeNode;
p->m_nvalue = startpreorder[0];
p->m_pLeft = NULL;
p->m_pRigt = NULL;
if (startpreorder == endpreorder)
return p;
int i = 0;
while (1)
{
if (startpreorder[0] == startinorder[i])
break;
else
++i;
/*if (i >= endpreorder - startpreorder + 1)
{
cout << "输入错误无法建立二叉树!" << endl;
return NULL;
}*/
}
if (i > 0)
p->m_pLeft = ConstructCore(startpreorder + 1, startpreorder + i, startinorder, startinorder + i-1);
if (i < endpreorder - startpreorder)
p->m_pRigt = ConstructCore(startpreorder + i + 1, endpreorder, startinorder + i + 1, endinorder);
return p;
}
BinaryTreeNode* Construct(int *preorder, int *inorder, int length)
{
if (preorder == NULL || inorder == NULL || length <= 0)
return NULL;
return ConstructCore(preorder, preorder + length - 1, inorder, inorder + length - 1);
}
//后序遍历打印二叉树
void LastCout(BinaryTreeNode *root)
{
if (root == NULL)
return;
LastCout(root->m_pLeft);
LastCout(root->m_pRigt);
cout << root->m_nvalue << " ";
}
void ACore(int *startpreorder, int *endpreorder, int *startinorder, int *endinorder)
{
if (startpreorder == endpreorder)
{
cout << startinorder[0] << " ";
return;
}
int i = 0;
while (1)
{
if (startpreorder[0] == startinorder[i])
break;
else
++i;
}
if (i > 0)
ACore(startpreorder + 1, startpreorder + i, startinorder, startinorder + i - 1);
if (i < endpreorder - startpreorder)
ACore(startpreorder + i + 1, endpreorder, startinorder + i + 1, endinorder);
cout << startpreorder[0] << " ";
}
// 输入前序遍历和中序遍历 输出后序遍历(前提 数组中数不能相等)
void A(int *preorder, int *inorder, int length)
{
if (preorder == NULL || inorder == NULL || length <= 0)
return;
else
ACore(preorder, preorder + length - 1, inorder, inorder + length - 1);
}
int main()
{
int preorder[] = { 1, 2, 4, 5, 6, 7, 3 };
int inorder[] = { 4, 2, 6, 5, 7, 1, 3 };
const int length = sizeof(preorder) / sizeof(preorder[0]);
BinaryTreeNode *p = Construct(preorder, inorder, length); //先构树 再输出后序遍历
LastCout(p);
cout << endl;
A(preorder, inorder, length); //直接输出后序遍历
cout << endl;
return 0;
}
0 0
- 输入前序遍历和中序遍历输出后序遍历——在构树和不构树两种情况下输出结果
- 剑指offer面试题:输入某二叉树的前序遍历和中序遍历的结果,输出后序遍历结果。
- 根据树的前序遍历和中序遍历构造树,输出后序遍历
- 输入前序遍历、中序遍历输出后续遍历
- 根据中序遍历和前序遍历输出后序遍历,自己的代码
- 由二叉树的前序遍历(后序遍历)和中序遍历输出后序遍历(前序遍历)
- 重建二叉树——输入前序、中序遍历构建二叉树并输出后序遍历
- 通过前序遍历和中序遍历重建二叉树以及输出后序遍历(Java实现)
- 二叉树--已知前序遍历和中序遍历,输出后续遍历
- Python练手之根据前序和中序&根据中序和后序重建二叉树,输出前序、中序和后序遍历结果
- 给出前序和中序遍历,输出后序遍历
- 二叉树问题-根据前序遍历结果和中序遍历结果得出后序遍历结果
- 二叉树遍历问题:已知中序遍历和后序遍历结果,求前序遍历结果
- 根据前序遍历、中序遍历构建二叉树,并后序遍历输出。
- 构造排序二叉树并输出前序遍历、中序遍历、后序遍历
- 根据前序遍历和中序遍历的结果确定后序遍历
- 根据前序与后序遍历构建二叉树,并以后序遍历结果输出
- 由前序和中序遍历建立二叉树并后序遍历输出二叉树
- PEATP
- 黑马程序员——多线程(synchronize_锁)
- WRITE_EXTERNAL_STORAGE权限的必要性
- Android源码分析-资源加载机制
- Cocos2d-x 3.4 之 TableView
- 输入前序遍历和中序遍历输出后序遍历——在构树和不构树两种情况下输出结果
- mysql 基础
- 【HEVC学习与研究】40、X265的下载和编译
- 利用Python做工具-1
- 最大子序列和问题
- 数塔
- php CI发送邮件
- 文章标题
- An internal error occurred during: "Importing Maven projects". 错误