小白专场-是否同一颗二叉搜索树-c语言实现

目录

  • 一、题意理解
  • 二、求解思路
  • 三、搜索树表示
  • 程序框架搭建
    • 3.1 如何建搜索树
    • 3.2 如何判别
    • 3.3 清空树

更新、更全的《数据结构与算法》的更新网站,更有python、go、人工智能教学等着你:https://www.cnblogs.com/nickchen121/p/11407287.html

一、题意理解

给定一个插入序列就可以唯一确定一颗二叉搜索树。然而,一颗给定的二叉搜索树却可以由多种不同的插入序列得到。例如:按照序列 {2, 1, 3} 和 {2, 3, 1}插入初始为空的二叉搜索树,都得到一样的结果。

问题:对于输入的各种插入序列,你需要判断它们是否能生成一样的二叉搜索树。

二、求解思路

两个序列是否对应相同搜索树的判别

  1. 分别建两颗搜索树的判别方法:根据两个序列分别建树,再判别树是否一样
  2. 不建树的判别方法

  1. 建一棵树,再判别其他序列是否与该树一致(本篇文章重点讨论)

    1. 搜索树表示
    2. 建搜索树T
    3. 判别一序列是否与搜索树T一致

三、搜索树表示

/* c语言实现 */

typedef struct TreeNode *Tree;
struct TreeNode
{
  int v;
  Tree Left, Right;
  int flag;
}

程序框架搭建

/* c语言实现 */

int main()
{
  对每组数据;
  * 读入N和L;
  * 根据第一行序列建树T;
  * 依据树T分别判别后面的L个序列是否能与T形成同一搜索树并输出结果;

  return 0;
}

int main()
{
  int N, L, i;
  Tree T;

  scanf("%d", &N);
  while (N) {
    scanf("%d", &L);
    T = MakeTree(N); // 读数据建搜索树T
    for (i=0; i<L, i++){
      if (Judge(T, N)) printf("Yes\n"); // 判别一序列是否与T构成一样的搜索树
      else printf("No\n");
      ResetT(T); // 清除T中的标记flag
    }
    FreeTree(T);
    scanf("%d", &N);
  }
  return 0;
}

3.1 如何建搜索树

/* c语言实现 */

Tree MakeTree(int N)
{
  Tree T;
  int i, V;

  scanf("%d", &V);
  T = NewNode(V);
  for (i=1; i<N; i++){
    scanf("%d", &V);
    T = Insert(T, V); // 按照搜索树顺序插入左右结点
  }
  return T;
}

Tree Insert(Tree T, int V)
{
  if (!T) T = NewNode(V);
  else{
    if (V > T->v)
      T->Right = Insert(T->Right, V);
    else
      T->Left = Insert(T->Left, V);
  }
  return T;
}

Tree NewNode(int V)
{
  Tree T = (Tree)malloc(sizeof(struct TreeNode));
  T->v = V;
  T->Left = T->Right = NULL; // 左右子树设置为空
  T->flag = 0;
  return T;
}

3.2 如何判别

如何判别序列 3,2,4,1 是否与树T一致?

方法:在树T中按顺序搜索序列 3,2,4,1 中的每个数

  • 如果每次搜索所经过的结点在前面均出现过,则一致
  • 否则(某次搜索中遇到前面未出现的结点),则不一致
/* c语言实现 */

int check(Tree T, int V)
{
  if (T->flag) {
    // 如果flag为1,则递归搜索子结点
    if (V < T->v) return check(T->Left, V);
    else if (V > T->v) return check(T->Right, V);
  }
  else{
    if (V == T->v){
      T->flag = 1;
      return 1;
    }
    else return 0;
  }
}

// 有bug版本的Judge方法:当发现序列中的某个树与T不一致时,必须把序列后面的数都读完,如序列 3,2,4,1 ,在读取2时就会发现两颗是不相同的搜索树,下面这段代码则不会继续读取 4,1,而是把它归入下一个序列
int Judge(Tree T, int N)
{
  int i, V;

  scanf("%d", &V);
  if (V != T->v) return 0;
  else T->flag = 1;

  for (i=1; i<N; i++){
    scanf("%d", &V);
    if (!check(T, V)) return 0;
  }
  return 1;
}

// 无bug版本的Judge方法
int Judge(Tree T, int N)
{
  int i, V, flag = 0; // flag:0代表目前还一致,1代表已经不一致

  scanf("%d", &V);
  if (V != T->v) flag = 1;
  else T->flag = 1;
  for (i=1; i<N; i++){
    scanf("%d", &V);
    if ((!flag) && (!check(T,V))) flag = 1;
  }
  if (flag) return 0;
  else return 1;
}

3.3 清空树

/* c语言实现 */

// 清除T中各结点的flag标记
void ResetT(Tree T)
{
  if (T->Left) ResetT(T->Left);
  if (T->Right) ResetT(T->Right);
  T->flag = 0;
}

// 释放T的空间
void FreeTree(Tree T)
{
  if (T->Left) FreeTree(T->Left);
  if (T->Right) FreeTree(T->Right);
  free(T);
}

原文地址:https://www.cnblogs.com/nickchen121/p/11562290.html

时间: 2024-10-08 05:21:40

小白专场-是否同一颗二叉搜索树-c语言实现的相关文章

小白专场-是否同一颗二叉搜索树-python语言实现

目录 一.二叉搜索树的相同判断 二.问题引入 三.举例分析 四.方法探讨 4.1 中序遍历 4.2 层序遍历 4.3 先序遍历 4.4 后序遍历 五.总结 六.代码实现 更新.更全的<数据结构与算法>的更新网站,更有python.go.人工智能教学等着你:https://www.cnblogs.com/nickchen121/p/11407287.html 一.二叉搜索树的相同判断 二叉搜索树是一种特殊的二叉树,在一定程度上是基于二分查找思想产生的,在它的任何一个节点node处,node的左子

给定一颗二叉搜索树,请找出其中的第k大的结点。例如, 5 / \ 3 7 /\ /\ 2 4 6 8 中,按结点数值大小顺序第三个结点的值为4。

/* struct TreeNode { int val; struct TreeNode *left; struct TreeNode *right; TreeNode(int x) : val(x), left(NULL), right(NULL) { } }; */ class Solution { public: TreeNode* KthNode(TreeNode* pRoot, int k) { //中序递归     int count = 0;              if(co

Java数据结构之二叉搜索树

Java数据结构之二叉搜索树 1.二叉搜索树组成 二叉搜索树又称为二叉排序树,它或者是一颗空树,或者是一颗具有如下特性的非空二叉树,需要满足一下三个条件: (1)若它的左子树非空,则左子树上所有结点的关键字均小于根结点的关键字: (2)若它的右子树非空,则右子树上所有结点的关键字均大于(可以等于)根结点的关键字. (3)左子树右子树本身又各是一颗二叉搜索树 在算法描述中,均以结点值的比较来代表其关键字的比较,因为若结点的值为类类型时,该类必须实现系统提供的java.lang.comparable

HDU 3791 二叉搜索树 题解

Problem Description 判断两序列是否为同一二叉搜索树序列 Input 开始一个数n,(1<=n<=20) 表示有n个需要判断,n= 0 的时候输入结束. 接下去一行是一个序列,序列长度小于10,包含(0~9)的数字,没有重复数字,根据这个序列可以构造出一颗二叉搜索树. 接下去的n行有n个序列,每个序列格式跟第一个序列一样,请判断这两个序列是否能组成同一颗二叉搜索树. Output 如果序列相同则输出YES,否则输出NO Sample Input 2 567432 543267

二叉搜索树的第k个结点-剑指Offer

二叉搜索树的第k个结点 题目描述 给定一颗二叉搜索树,请找出其中的第k大的结点.例如,5 / \ 3 7 /\ /\ 2 4 6 8 中,按结点数值大小顺序第三个结点的值为4. 思路 对于二叉搜索树,中序遍历的结果是按照顺序来的,我们设置一个变量用来计数,递归的遍历树,如果到了第k个,则把那个数取出来,我在这用的是ArrayList来存储那个结点 还可以在递归方法中直接返回结点,无需用ArrayList跟踪存储,更加简化 代码 import java.util.ArrayList; /* pub

九度OJ刷题——1009:二叉搜索树

题目描述: 判断两序列是否为同一二叉搜索树序列 输入: 开始一个数n,(1<=n<=20) 表示有n个需要判断,n= 0 的时候输入结束.接下去一行是一个序列,序列长度小于10,包含(0~9)的数字,没有重复数字,根据这个序列可以构造出一颗二叉搜索树.接下去的n行有n个序列,每个序列格式跟第一个序列一样,请判断这两个序列是否能组成同一颗二叉搜索树. 输出: 如果序列相同则输出YES,否则输出NO 样例输入: 2 567432 543267 576342 0 样例输出: YES NO 这题我的思

二叉搜索树比较

前言: 二叉搜索树是二叉排序树,左子树比根小,右子树比根大,所以它建树的方式和普通建树的方式稍有不同,每次都要和根节点往下比较而确定位置,然后采用遍历二叉树节点的方式确定两棵树是否完全相等. 言归正传,在牛客网页编译器里运行结果有出入,但是在本地调试是没有问题的,而且检验,也没找到有什么逻辑错,这个问题存疑~~~ 题目描述 判断两序列是否为同一二叉搜索树序列 输入描述: 开始一个数n,(1<=n<=20) 表示有n个需要判断,n= 0 的时候输入结束.接下去一行是一个序列,序列长度小于10,包

九度oj 题目1009:二叉搜索树

题目1009:二叉搜索树 时间限制:1 秒 内存限制:32 兆 特殊判题:否 提交:5733 解决:2538 题目描述: 判断两序列是否为同一二叉搜索树序列 输入: 开始一个数n,(1<=n<=20) 表示有n个需要判断,n= 0 的时候输入结束.接下去一行是一个序列,序列长度小于10,包含(0~9)的数字,没有重复数字,根据这个序列可以构造出一颗二叉搜索树.接下去的n行有n个序列,每个序列格式跟第一个序列一样,请判断这两个序列是否能组成同一颗二叉搜索树. 输出: 如果序列相同则输出YES,否

编程算法 - 二叉搜索树 与 双向链表 代码(C++)

二叉搜索树 与 双向链表 代码(C++) 本文地址: http://blog.csdn.net/caroline_wendy 题目:输入一颗二叉搜索树, 将该二叉搜索树转换成一个排序的双向链表. 要求不能创建不论什么新的结点, 仅仅能调整数中结点的指针的指向. 方法: 使用中序遍历每个结点, 并进行连接, 即左子树指前, 右子树指后, 并保存前一个节点. 本程序包括算法原理, 測试程序, 及 输出. /* * main.cpp * * Created on: 2014.6.12 * Author