#include <stdio.h>
 #include <stdlib.h>
 #include <string.h>
 #include <stdbool.h>

 typedef char ElemType;

 typedef struct BinTree
 {
     ElemType data;
     struct BinTree *left;
     struct BinTree *right;
 }BinTree;

 bool TreeCmp(BinTree * a, BinTree * b); //判断a树与b树是否同构
 BinTree * BinTree_new(int n);

 int main()
 {
     int n;
     scanf("%d", &n);
     BinTree * a = BinTree_new(n);
     scanf("%d", &n);
     BinTree * b = BinTree_new(n);

     bool flag = TreeCmp(a, b);
     if (flag)
         printf("Yes");
     else
         printf("No");

     ;
 }

 BinTree * BinTree_new(int n)
 {
     )
     {
         return  NULL;
     }
     else
     {
         int i, li, ri;
         ElemType c, lc, rc;
         BinTree * T = (BinTree *)malloc(n * sizeof(BinTree));
         bool *head = (bool *)malloc(n * sizeof(bool));

         memset(head, true ,sizeof(head));

         ; i < n ; ++i )
         {
             scanf(" %c %c %c", &c, &lc, &rc);

             li = lc-';
             ri = rc-';

             T[i].data = c;

             if (lc != '-')
             {
                 T[i].left = &T[li];
                 head[li] = false;
             }
             else
                 T[i].left = NULL;

             if (rc != '-')
             {
                 T[i].right = &T[ri];
                 head[ri] = false;
             }
             else
                 T[i].right = NULL;

         }

         //寻找树的树根(树根没有其它的结点指向它)
         ; i < n ; ++i )
             if (head[i] == true)
                 break;
         free(head);
         return &T[i];
     }
 }

 bool TreeCmp(BinTree * a, BinTree * b)
 {
     if (a == NULL && b == NULL)//两棵树都为空
         return true;

     if (a == NULL || b == NULL)//有一棵树为空
         return false;

     if (a->data != b->data)//树结点的值不相等
         return false;

     if (a->left == NULL && b->left == NULL)//两棵树的左子树都为空
         return TreeCmp(a->right, b->right);//就比较右子树

     //两棵树的左子树都不为空,且两个值相等就比较两棵树的子树
     if (a->left != NULL && b->left != NULL &&(a->left->data == b->left->data))
         return (TreeCmp(a->left,b->left)&&TreeCmp(a->right,b->right));

     //交换后再比较
     else
         return (TreeCmp(a->left,b->right)&&TreeCmp(a->right,b->left));
 }

03-树1 树的同构 (C语言链表实现)的更多相关文章

  1. 小白专场-树的同构-c语言实现.md

    目录 一.题意理解 二.求解思路 2.1 二叉树表示 2.2 程序框架搭建 2.3 如何建二叉树 2.4 如何判别两二叉树同构 更新.更全的<数据结构与算法>的更新网站,更有python. ...

  2. 【查找结构5】多路查找树/B~树/B+树

    在前面专题中讲的BST.AVL.RBT都是典型的二叉查找树结构,其查找的时间复杂度与树高相关.那么降低树高自然对查找效率是有所帮助的.另外还有一个比较实际的问题:就是大量数据存储中,实现查询这样一个实 ...

  3. 9-11-Trie树/字典树/前缀树-查找-第9章-《数据结构》课本源码-严蔚敏吴伟民版

    课本源码部分 第9章  查找 - Trie树/字典树/前缀树(键树) ——<数据结构>-严蔚敏.吴伟民版        源码使用说明  链接☛☛☛ <数据结构-C语言版>(严蔚 ...

  4. HTTP协议漫谈 C#实现图(Graph) C#实现二叉查找树 浅谈进程同步和互斥的概念 C#实现平衡多路查找树(B树)

    HTTP协议漫谈   简介 园子里已经有不少介绍HTTP的的好文章.对HTTP的一些细节介绍的比较好,所以本篇文章不会对HTTP的细节进行深究,而是从够高和更结构化的角度将HTTP协议的元素进行分类讲 ...

  5. Tire树(字典树)

    from:https://www.cnblogs.com/justinh/p/7716421.html Trie,又经常叫前缀树,字典树等等.它有很多变种,如后缀树,Radix Tree/Trie,P ...

  6. BZOJ 3110: [Zjoi2013]K大数查询 [树套树]

    3110: [Zjoi2013]K大数查询 Time Limit: 20 Sec  Memory Limit: 512 MBSubmit: 6050  Solved: 2007[Submit][Sta ...

  7. BZOJ4170 极光(CDQ分治 或 树套树)

    传送门 BZOJ上的题目没有题面-- [样例输入] 3 5 2 4 3 Query 2 2 Modify 1 3 Query 2 2 Modify 1 2 Query 1 1 [样例输出] 2 3 3 ...

  8. Atitit 常见的树形结构 红黑树  二叉树   B树 B+树  Trie树 attilax理解与总结

    Atitit 常见的树形结构 红黑树  二叉树   B树 B+树  Trie树 attilax理解与总结 1.1. 树形结构-- 一对多的关系1 1.2. 树的相关术语: 1 1.3. 常见的树形结构 ...

  9. bzoj3262: 陌上花开(树套树)

    #include <iostream> #include <cstdio> #include <cstring> #include <cmath> #i ...

  10. bzoj3295: [Cqoi2011]动态逆序对(树套树)

    #include <iostream> #include <cstdio> #include <cstring> #include <cmath> #i ...

随机推荐

  1. 《Entity Framework 6 Recipes》中文翻译系列 (7) -----第二章 实体数据建模基础之拆分实体到多表以及拆分表到多实体

    2-6 拆分实体到多表 问题 你有两张或是更多的表,他们共享一样的主键,你想将他们映射到一个单独的实体. 解决方案 让我们用图2-15所示的两张表来演示这种情况. 图 2-15,两张表,Prodeuc ...

  2. Android开发学习之路-图片颜色获取器开发(1)

    系列第一篇,从简单的开始,一步一步完成这个小项目. 颜色获取就是通过分析图片中的每个像素的颜色,来分析整个图片的主调颜色,有了主调颜色,我们可以用于图片所在卡片的背景或者标题颜色,这样整体感更加强烈. ...

  3. Tornado框架中视图模板Template的使用

    上文的程序中有这样一段: class MessageHandler(tornado.web.RequestHandler): def get(self): self.write(''' <htm ...

  4. angularjs指令参数transclude

    angularjs指令参数transclude transclude翻译为嵌入,和之前看到的vue中的slots作用差不多,目的是将指令元素的子内容嵌入到指令的模板中 定义指令 <div sid ...

  5. OpenCascade Primitives BRep-Cone

    OpenCascade Primitives BRep-Cone eryar@163.com Abstract. BRep is short for Boundary Representation. ...

  6. MVC实用架构设计(三)——EF-Code First(4):数据查询

    前言 首先对大家表示抱歉,这个系列已经将近一个月没有更新了,相信大家等本篇更新都等得快失望了.实在没办法,由于本人水平有限,写篇博客基本上要大半天的时间,最近实在是抽不出这么长段的空闲时间来写.另外也 ...

  7. 用scikit-learn和pandas学习Ridge回归

    本文将用一个例子来讲述怎么用scikit-learn和pandas来学习Ridge回归. 1. Ridge回归的损失函数 在我的另外一遍讲线性回归的文章中,对Ridge回归做了一些介绍,以及什么时候适 ...

  8. react+redux教程(一)connect、applyMiddleware、thunk、webpackHotMiddleware

    今天,我们通过解读官方示例代码(counter)的方式来学习react+redux. 例子 这个例子是官方的例子,计数器程序.前两个按钮是加减,第三个是如果当前数字是奇数则加一,第四个按钮是异步加一( ...

  9. javascript模拟继承

    javascript作为前端开发的标配技能,如果不掌握好它的三大特点:1.原型 2.作用域 3. 闭包 ,又怎么可以说你学好了这门语言呢?如果标配的技能都没有撑握好,怎么可以任性的玩耍呢?怎么验证自己 ...

  10. How to implement a neural network

    神经网络的实践笔记 link: http://peterroelants.github.io/posts/neural_network_implementation_part01/ 1. 生成训练数据 ...