重建二叉树
来源:互联网 发布:剪歌拼歌软件 编辑:程序博客网 时间:2024/04/30 16:23
#include <stdio.h>
#include <stdlib.h>
#define TREELEN 6
struct Node
{
struct Node * pLeft;
struct Node * pRight;
char chValue;
};
void ReBuildTree(char * pPreOrder, char * pInOrder, int nTreeLen, struct Node **pRoot)
{
//检查边界条件
if(pPreOrder == NULL || pInOrder == NULL)
{
return;
}
//获得前序遍历的第一个节点
struct Node * pTemp = (struct Node *)malloc(sizeof(struct Node));
pTemp -> chValue = *pPreOrder;
pTemp -> pLeft = NULL;
pTemp -> pRight = NULL;
//如果节点为空,把当前节点复制到根节点
if(*pRoot == NULL)
{
*pRoot = pTemp;
}
//如果当前树长度为1,那么已经是最后一个节点
if(nTreeLen == 1)
{
return;
}
//寻找子树长度
char * pOrgInOrder = pInOrder;
char * pLeftEnd = pInOrder;
int nTempLen = 0;
//找到左子树德结尾
while(*pPreOrder != *pLeftEnd)
{
if(pPreOrder == NULL || pLeftEnd == NULL)
{
return;
}
nTempLen++;
//记录临时表长度,以免溢出
if(nTempLen > nTreeLen)
{
break;
}
pLeftEnd++;
}
//寻找左子树长度
int nLeftLen = 0;
nLeftLen = (int)(pLeftEnd - pOrgInOrder);
//寻找右子树长度
int nRightLen = 0;
nRightLen = nTreeLen - nLeftLen - 1;
//重建左子树
if(nLeftLen > 0)
{
ReBuildTree(pPreOrder + 1, pInOrder, nLeftLen, &((*pRoot) -> pLeft));
}
//重建右子树
if(nRightLen > 0)
{
ReBuildTree(pPreOrder + nLeftLen + 1, pInOrder + nLeftLen + 1, nRightLen, &((*pRoot) -> pRight));
}
}
int main()
{
char szPreOrder[TREELEN] = {'a', 'b', 'd', 'c', 'e', 'f'};
char szInOrder[TREELEN] = {'d', 'b', 'a', 'e', 'c', 'f'};
struct Node * pRoot = NULL;
ReBuildTree(szPreOrder, szInOrder, TREELEN, &pRoot);
//printf("Hello world!\n");
return 0;
}
#include <stdlib.h>
#define TREELEN 6
struct Node
{
struct Node * pLeft;
struct Node * pRight;
char chValue;
};
void ReBuildTree(char * pPreOrder, char * pInOrder, int nTreeLen, struct Node **pRoot)
{
//检查边界条件
if(pPreOrder == NULL || pInOrder == NULL)
{
return;
}
//获得前序遍历的第一个节点
struct Node * pTemp = (struct Node *)malloc(sizeof(struct Node));
pTemp -> chValue = *pPreOrder;
pTemp -> pLeft = NULL;
pTemp -> pRight = NULL;
//如果节点为空,把当前节点复制到根节点
if(*pRoot == NULL)
{
*pRoot = pTemp;
}
//如果当前树长度为1,那么已经是最后一个节点
if(nTreeLen == 1)
{
return;
}
//寻找子树长度
char * pOrgInOrder = pInOrder;
char * pLeftEnd = pInOrder;
int nTempLen = 0;
//找到左子树德结尾
while(*pPreOrder != *pLeftEnd)
{
if(pPreOrder == NULL || pLeftEnd == NULL)
{
return;
}
nTempLen++;
//记录临时表长度,以免溢出
if(nTempLen > nTreeLen)
{
break;
}
pLeftEnd++;
}
//寻找左子树长度
int nLeftLen = 0;
nLeftLen = (int)(pLeftEnd - pOrgInOrder);
//寻找右子树长度
int nRightLen = 0;
nRightLen = nTreeLen - nLeftLen - 1;
//重建左子树
if(nLeftLen > 0)
{
ReBuildTree(pPreOrder + 1, pInOrder, nLeftLen, &((*pRoot) -> pLeft));
}
//重建右子树
if(nRightLen > 0)
{
ReBuildTree(pPreOrder + nLeftLen + 1, pInOrder + nLeftLen + 1, nRightLen, &((*pRoot) -> pRight));
}
}
int main()
{
char szPreOrder[TREELEN] = {'a', 'b', 'd', 'c', 'e', 'f'};
char szInOrder[TREELEN] = {'d', 'b', 'a', 'e', 'c', 'f'};
struct Node * pRoot = NULL;
ReBuildTree(szPreOrder, szInOrder, TREELEN, &pRoot);
//printf("Hello world!\n");
return 0;
}
- 3.9重建二叉树
- 重建二叉树
- 二叉树重建
- 二叉树重建
- 二叉树的重建
- 重建二叉树
- 重建二叉树
- 重建二叉树
- 重建二叉树
- 重建二叉树
- 重建二叉树
- 重建二叉树
- 重建二叉树
- 二叉树重建
- 二叉树重建
- 重建二叉树
- 重建二叉树
- 重建二叉树
- Nginx+PHP FastCgi大幅度优化提速
- 配置文件2012.2.14
- Android 中的service
- Centos学习笔记—系统引导
- 超垃圾的netbean快捷键大全,和VS2008+有的 比
- 重建二叉树
- mysql 触发器
- mysql 游标
- mysql event
- mysql information_schema 视图信息
- ftp
- 环境变量
- teleport pro网站下载工具
- 进程通信之一使用WM_COPYDATA