输入某二叉树的前序遍历和中序遍历的结果,重建出这棵二叉树,假设输入的前序遍历和中序遍历的结果中都不含重复的数字。例如,输入前序遍历序列{1,2,4,7,3,5,6,8}和中序遍历序列{4,7,2,1,5,3,8,6},则重建出这棵满足前序遍历和中序遍历的二叉树并输出它的头结点。
对一棵二叉树前序遍历的顺序是“根结点->左结点->右结点”,而中序遍历的顺序是“左结点->根节点->右结点”,因此,一般的思路都是酱紫的:
前序遍历列表中,第一个数据肯定是根节点,而中序遍历列表中,第一个数据肯定是树的最左结点,这样就可以得知,在前序遍历中,从根结点到最左结点一定是树的最左分支,也就是“1->2->4”;
接下来,在中序遍历中,访问完最左结点4之后因为其左结点为NULL要访问的就是4的右分支的最左结点了,为7,而在前序遍历中访问到最左结点之后就要访问右结点,发现也为7,说明7就是最左结点4的右分支上的最左结点,也就是只有7一个右结点;
然后,在中序遍历中访问完最左结点也就是以4为根节点子树之后,就要回到4结点的父节点了,也就是2,再往下访问是根节点1,也就是2并没有右结点;
至此会发现1为根节点的左子树已经全部访问完了;
上面没有再继续往下分析,是因为会发现,上面说的一堆虽然能把树给重建出来