重建二叉树NYOJ221题 NYOJ756题

2024-06-11 15:48

本文主要是介绍重建二叉树NYOJ221题 NYOJ756题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

(一)前序中序求后序:

思路:

结点 getRoot(前序 中序)

{

c =  前序第一个字符;

pos = 在中序的位置;

len1 = 中序pos左半部分长度;

len2 = 中序pos右半部分长度;

新建结点 r,令r的元素等于c;

r 的左儿子 = getRoot(前序位置开始的len1长度部分,中序pos位置左半部分)

r 的 右儿子 = getRoot(前序位置len1开始的右半部分, 中序pos位置的有半部分)

return r;

 
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
typedef struct node
{char data;struct node *lchild;struct node *rchild;
}Node;
char prev[30], in[30];
Node * getRoot(char *prev, int p1, int p2, char *in, int i1, int i2);
void postOrder(Node *T);
int main(void)
{while(scanf("%s%s", prev, in) != EOF){Node *T;T = getRoot(prev, 0, strlen(prev) - 1, in, 0, strlen(in) - 1);postOrder(T);printf("\n");}return 0;
}
Node * getRoot(char *prev, int p1, int p2, char *in, int i1, int i2)
{char c = prev[p1];//前序的第一个字符;int pos, i, flag;if(prev == NULL || p1 > p2 || p1 < 0 || p2 > strlen(prev) || in == NULL || i1 > i2 || i1 < 0 || i2 > strlen(in))return NULL;//返回空结点for(i = i1; i <= i2; i++)//确定pos = c在in中的位置{if(prev[p1] == in[i]){pos = i;flag = 1;//标记是否找到了c;break;}}if(flag == 0)//返回空结点return NULL;Node *r;r = (Node *)malloc(sizeof(Node));r->data = c;r->lchild = getRoot(prev, p1 + 1, p1 + pos - i1, in, i1, pos - 1);//确定好传递的数组范围;r->rchild = getRoot(prev, p1 + pos - i1 + 1, p2, in, pos + 1, i2);return  r;
}
void postOrder(Node *T)
{if(T == NULL)return ;postOrder(T->lchild);postOrder(T->rchild);printf("%c", T->data);
}        
}

(二)

知道中序后序求前序:

 
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
typedef struct node
{char data;struct node *lchild;struct node *rchild;
}Node;
char post[30], in[30];
char *strrev(char string[]);
Node * getRoot(char *post, int p1, int p2, char *in, int i1, int i2);
void prevOrder(Node *T);
int main(void)
{while(scanf("%s%s", post, in) != EOF){Node *T;strcpy(post, strrev(post));//逆转后序;T = getRoot(post, 0, strlen(post) - 1, in, 0, strlen(in) - 1);prevOrder(T);printf("\n");}return 0;
}
Node * getRoot(char *post, int p1, int p2, char *in, int i1, int i2)
{char c = post[p1];//前序的第一个字符;int pos, i, flag;if(post == NULL || p1 > p2 || p1 < 0 || p2 > strlen(post) || in == NULL || i1 > i2 || i1 < 0 || i2 > strlen(in))return NULL;//越界时,返回空结点for(i = i1; i <= i2; i++)//确定pos = c在in中的位置{if(post[p1] == in[i]){pos = i;flag = 1;//标记是否找到了c;break;}}if(flag == 0)//返回空结点return NULL;Node *r;r = (Node *)malloc(sizeof(Node));r->data = c;r->lchild = getRoot(post, p1 + i2 - pos + 1, p2, in, i1, pos - 1);//确定好传递的数组范围;r->rchild = getRoot(post, p1 + 1, p2 - (pos - i1), in, pos + 1, i2);return  r;
}
void prevOrder(Node *T)
{if(T == NULL)return ;printf("%c", T->data);prevOrder(T->lchild);prevOrder(T->rchild);
}
char *strrev(char string[])//*** 字符串逆转; 
{ char s[1010]; int len = strlen(string); int i, j = 0; for(i = len - 1; i >= 0; i --) { s[j ++] = string[i]; } s[j] = 0; return s; 
} 




这篇关于重建二叉树NYOJ221题 NYOJ756题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1051606

相关文章

剑指offer(C++)--平衡二叉树

题目 输入一棵二叉树,判断该二叉树是否是平衡二叉树。 class Solution {public:bool IsBalanced_Solution(TreeNode* pRoot) {if(pRoot==NULL)return true;int left_depth = getdepth(pRoot->left);int right_depth = getdepth(pRoot->rig

二叉树三种遍历方式及其实现

一、基本概念 每个结点最多有两棵子树,左子树和右子树,次序不可以颠倒。 性质: 1、非空二叉树的第n层上至多有2^(n-1)个元素。 2、深度为h的二叉树至多有2^h-1个结点。 3、对任何一棵二叉树T,如果其终端结点数(即叶子结点数)为n0,度为2的结点数为n2,则n0 = n2 + 1。 满二叉树:所有终端都在同一层次,且非终端结点的度数为2。 在满二叉树中若其深度为h,则其所包含

LeetCode 算法:二叉树的中序遍历 c++

原题链接🔗:二叉树的中序遍历 难度:简单⭐️ 题目 给定一个二叉树的根节点 root ,返回 它的 中序 遍历 。 示例 1: 输入:root = [1,null,2,3] 输出:[1,3,2] 示例 2: 输入:root = [] 输出:[] 示例 3: 输入:root = [1] 输出:[1] 提示: 树中节点数目在范围 [0, 100] 内 -100 <= Node.

C++ 重建二叉树(递归方法)

/*** struct TreeNode {* int val;* struct TreeNode *left;* struct TreeNode *right;* TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}* };*/#include <vector>class Solution {public:/*** 代码

数据结构:二叉树详解 c++信息学奥赛基础知识讲解

目录 一、二叉树的定义 二、二叉树的形态 三、二叉树的性质 四、二叉树的存储 五、二叉树的创建与遍历(递归) 六、二叉树实现 创建二叉树 展示二叉树 1、计算数的高度 2、计算数的叶子数量 3、计算数的宽度 4、层次遍历 5、前序遍历 递归写法 非递归写法 6、中序遍历 递归写法 非递归写法 7、后序遍历 递归写法 非递归写法 8、输出根节点到所有叶

秋招突击——6/22——复习{区间DP——加分二叉树,背包问题——买书}——新作{移除元素、实现strStr()}

文章目录 引言复习区间DP——加分二叉树个人实现 背包问题——买书个人实现参考实现 新作移除元素个人实现参考思路 找出字符串中第一个匹配项的下标个人实现参考实现 总结 引言 今天做了一个噩梦,然后流了一身汗,然后没起来,九点多才起床背书。十点钟才开始把昨天那道题题目过一遍,然后十一点才开始复习题目,为了不耽误下午的时间,所以这里的就单纯做已经做过的题目,主打一个有量,不在学

leetcode刷题(46)——236. 二叉树的最近公共祖先

这道题比235略难一些 给定一个二叉树, 找到该树中两个指定节点的最近公共祖先。 百度百科中最近公共祖先的定义为:“对于有根树 T 的两个结点 p、q,最近公共祖先表示为一个结点 x,满足 x 是 p、q 的祖先且 x 的深度尽可能大(一个节点也可以是它自己的祖先)。” 例如,给定如下二叉树: root = [3,5,1,6,2,0,8,null,null,7,4] 示例 1: 输入:

leetcode刷题(97)——106. 从中序与后序遍历序列构造二叉树

根据一棵树的中序遍历与后序遍历构造二叉树。 注意: 你可以假设树中没有重复的元素。 例如,给出 中序遍历 inorder = [9,3,15,20,7]后序遍历 postorder = [9,15,7,20,3] 返回如下的二叉树: 3/ \9 20/ \15 7 看下后序和中序遍历的框架: void traverse(TreeNode root) {trave

leetcode刷题(97)——105. 从前序与中序遍历序列构造二叉树

根据一棵树的前序遍历与中序遍历构造二叉树。 注意: 你可以假设树中没有重复的元素。 例如,给出 前序遍历 preorder = [3,9,20,15,7]中序遍历 inorder = [9,3,15,20,7] 返回如下的二叉树: 3/ \9 20/ \15 7 1.先回顾前序遍历和中序遍历的框架: void traverse(TreeNode root) {//

【算法】二叉树 - 理论基础

1.种类 1.1 满二叉树 只有度为0和2的节点,且度为0的节点都都在同一层。深度为k,有2^k-1个节点。 1.2 完全二叉树 在完全二叉树中,除了最底层节点可能没填满外,其余每层节点数都达到最大值,并且最下面一层的节点都集中在该层最左边的若干位置。若最底层为第 h 层(h从1开始),则该层包含 1~ 2^(h-1) 个节点。 1.2 二叉树搜索树 有数值的有序树 若它的左