N元树中的同构性

同构被定义为两棵树具有相同或镜像结构。在镜像结构的情况下,左节点的数据将始终与右节点匹配。例如,我们将取一个最接近镜像的数字,看看它的反向是什么,这就是同构的真正概念。

在本文中,我们将检查两个不同的二叉树是否同构。

让我们以N叉树的同构为例-

N元树中的同构性

请注意,L代表左节点,而R代表右节点

左侧最左第二分区的P和Q树的镜像结构

N元树中的同构性

这两个图示展示了它们如何通过给出四个匹配条件(P和Q的根节点)来彼此同构。

左-左节点可以匹配。

要么可以匹配右-右节点。

左右节点均可匹配。

要么右左无法匹配。

语法

程序中使用了以下语法−

struct name_of_structure{   data_type var_name;      // data member or field of the structure.}

登录后复制

参数

struct − 这个关键字用于表示结构数据类型。

name_of_structure − 我们为结构提供任何名称。

结构是将各种相关变量集中在一个地方的集合。

算法

我们将使用一个名为‘iostream’的头文件来开始程序。

我们正在创建名为‘tree_node’的结构,其中包含整数类型‘d’和初始化指针变量- ‘l’‘r’,分别表示左右子节点的数据。

现在我们使用一个名为‘create_node()’的函数创建另一个结构,该函数接受一个名为‘data’的参数来指定根节点的值。同时,我们创建一个名为‘tree_node’的指针,并使用给定的数据来初始化左子节点和右子节点的指针为空,并返回根节点。使用这个函数,我们将插入左子节点和右子节点的节点。

我们正在创建一个名为‘check_isomorphism_tree 的函数,它使用布尔数据类型,以两个tree_node指针pq作为输入参数,并返回一个布尔值。在其中,我们两次创建一个“if语句”来检查p中的数据是否等同于q中的数据。

检查p和q是否都为null,如果是,则返回true,因为树是同构的。

检查 p 或 q 中是否有任何一个为 null,如果是,则返回 false,因为这两棵树不是同构的。

‘check_isomorphism_tree’函数中,我们使用逻辑运算符“&&”和“||”递归检查节点‘p’‘q’的所有可能的左右子节点组合。

我们从主函数开始,创建两个树节点“p”和“q”来提供信息。

在主函数中,我们使用if语句调用‘check_isomorphism_tree’函数,并传递给定的参数p和q来验证这些整数值是否同构。如果它们是同构的,则打印语句为“这个给定的节点信息将生成同构树”,否则相反。

Example

的中文翻译为:

示例

在这个程序中,我们将检查两个二叉树是否同构。

#includeusing namespace std;struct tree_node{   int d;   tree_node*l;  // l = left   tree_node*r;  // r = right};struct tree_node* create_node(int data){   struct tree_node*root= new tree_node;   root->d= data;   root->l= NULL;   root->r= NULL;   return root;    }bool check_isomorphism_tree(tree_node*p, tree_node*q)  {// p and q both are different tree   if(p==NULL and q==NULL){      return true;   }   if(p==NULL or q==NULL){      return false;   }   // return all the possible condition    return (p->d==q->d && ((check_isomorphism_tree(p->l,q->r)&& check_isomorphism_tree(p->r,q->l))||(check_isomorphism_tree(p->l,q->l)&& check_isomorphism_tree(p->r,q->r))));}int main(){   // Tree of root pstruct tree_node *p = create_node(10);    p->l  = create_node(5);    p->r = create_node(4);    p->l->l = create_node(11);    p->r->r = create_node(12);   p->l->r = create_node(51);    p->r->l = create_node(6);    p->l->r->l = create_node(7); // left->right->left   p->l->l->l = create_node(9); // left->left->left   // Tree of root q   struct tree_node *q = create_node(10);    q->l  = create_node(5);    q->r = create_node(4);    q->l->l = create_node(11);    q->r->r = create_node(12);   q->l->r = create_node(51);    q->r->l = create_node(6);    q->l->r->l = create_node(7);    q->l->l->l = create_node(9);   if(check_isomorphism_tree(p,q)){      cout

输出

This given information of node will make isomorphism tree

登录后复制

结论

在这个程序中,我们理解了N叉树中同构的概念。我们看到了如何使用结构来表示树节点,以及使用左-左节点、右-左节点、左-右-左节点等来构建树,以下操作有助于满足树的同构性质。

以上就是N元树中的同构性的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2581654.html

(0)
上一篇 2025年3月6日 14:01:11
下一篇 2025年3月6日 14:01:19

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • C语言程序的入口函数是什么?

    C语言程序的启动点在哪里? C语言是一种广泛应用于计算机编程的高级编程语言。在C语言中,我们经常需要编写一个带有main函数的程序,作为程序的入口点。那么,C语言程序的启动点到底在哪里呢? C语言的启动点是main函数。在C语言程序中,ma…

    2025年3月6日
    200
  • C语言的前景如何?行业专家展望未来发展

    随着信息技术的迅速发展,编程语言也在不断演进和更新。而C语言作为一门古老而又经典的编程语言,其前景如何是许多人都关心和探讨的问题。在这篇文章中,我们将邀请一位C语言专业人士来解读C语言未来趋势。 C语言作为一门高级程序设计语言,具有结构化、…

    2025年3月6日
    200
  • 探索C语言之后的职业道路

    探索C语言之后的职业道路 C语言作为一门广泛应用于嵌入式系统、操作系统和高性能计算等领域的编程语言,深受程序员们的喜爱。学习和掌握了C语言,将会为职业生涯带来广阔的发展前景。本文将探索在掌握C语言之后,程序员们可以选择的职业道路。 首先,一…

    2025年3月6日
    200
  • 选择合适的编辑器,打造高效的C语言开发环境

    搭建高效C语言开发环境:选择适合你的C语言编辑器 简介:对于C语言开发者来说,选择一款适合自己的编辑器是非常重要的。一个好的编辑器不仅可以提高开发效率,还能提供更多的便利功能。本文将介绍几款常用的C语言编辑器,并提供选择的建议。 一、Vis…

    2025年3月6日
    200
  • 解决win10开机缓慢的方法及详解

    很多用户们在使用win10系统的时候,有时候发现开机速度极慢,不知道该需要怎么解决,那么这个详细的解决方法教程,就为广大用户们提供吧~ win10开机慢怎么解决: 1、打开控制面板,然后找到“电源选项”。 2、然后在右方点击“选择电源按钮的…

    2025年3月5日 互联网
    200
  • win11安全中心使用指南

    win11支持用户在安全中心里修改防火墙、杀毒软件等安全设置,那么win11安全中心怎么打开呢,其实只要找到隐私和安全性设置就可以了。 win11安全中心怎么打开: 1、首先点击底部开始菜单,打开“设置” 2、然后找到左边栏中的“隐私和安全…

    2025年3月5日 互联网
    200
  • 分配单元大小越大越好吗

    很多小伙伴在硬盘或者u盘格式化的时候,遇见格式化分配单元大小是什么意思呢?以及分配单元大小多少比较合适呢?是不是越大越好呢?一般情况下选择默认的分配大小,或者适中就好,具体的介绍下面一起来看看吧。 分配单元大小适中好 一般来说,分配单元大小…

    2025年3月5日
    200
  • win10镜像和原版有什么区别

    最近有小伙伴反应自己想下载win10镜像文件,但是却不知道和原版有是什么区别,这可怎么办呢?其实他们是两个不同的概念,是一种文件格式,今天小编带来了详细的区别,具体的一起来看看吧。 win10镜像和原版有区别介绍 镜像下载: >&gt…

    2025年3月5日
    200
  • win10重置初始化失败

    win10系统是一款有着非常多便利性功能的优秀系统,如果熟练的应用这些功能用户们的win10系统使用体验将会大大的增加!但是近日来却有很多的小伙伴们反应自己在使用重置功能时出现了失败的现象!针对这个问题小编今天为大家带来了系统重置初始化失败…

    2025年3月5日 互联网
    200
  • Go 语言中的标准库有哪些?

    go语言标准库是go语言内置的一组工具箱,它提供了一系列的库和包,这些库和包可以帮助我们轻松地完成各种任务。标准库包含了各种工具,包括字符串处理、文件操作、网络编程、加密等等。在go语言中,标准库是非常重要的,因为它是go语言的核心部分。在…

    编程技术 2025年3月2日
    200

发表回复

登录后才能评论