Isomorphism in N-ary trees
Isomorphism is defined as two trees having the same or mirrored structure. In the case of a mirror structure, the left node's data will always match the right node. For example, we will take a number that is the closest mirror image and see what its inverse is, which is the true concept of isomorphism.
In this article, we will check whether two different binary trees are isomorphic.
Let us take the isomorphism of N-ary tree as an example-

Please note that L represents the left node and R represents the right node
Mirror structure of P and Q trees in the second leftmost partition on the left

These two diagrams show how they are isomorphic to each other by giving four matching conditions (root nodes of P and Q).
Left-left nodes can match.
Either can match right-right nodes.
Both the left and right nodes can be matched.
Either right or left cannot match.
grammar
The following syntax is used in the program −
struct name_of_structure{ data_type var_name; // data member or field of the structure. }
parameter
struct − This keyword is used to represent the structure data type.
name_of_structure − We provide any name for the structure.
A structure is a collection of various related variables in one place.
algorithm
We will start the program with a header file called 'iostream'.
We are creating a structure called 'tree_node' containing an integer type 'd' and an initialized pointer variable - 'l' and 'r', respectively represent the data of the left and right child nodes.
Now we create another structure using a function called 'create_node()' which accepts a parameter called 'data' to specify the root The value of the node. At the same time, we create a pointer named 'tree_node' and use the given data to initialize the left and right child node pointers to null and return the root node. Using this function, we will insert the node of left child node and right child node.
We are creating a function called 'check_isomorphism_tree which uses the boolean data type, taking two tree_node pointers p and q as input parameter and returns a Boolean value. In it, we create an "if statement" twice to check if the data in p is equal to the data in q.
Check if both p and q are null, if so, return true because the tree is isomorphic.
Check if either p or q is null, and if so, return false because the two trees are not isomorphic.
In the 'check_isomorphism_tree' function, we use the logical operators "&&" and "||" to recursively check the nodes 'p' and 'q All possible combinations of left and right child nodes of '.
We start from the main function and create two tree nodes "p" and "q" to provide information.
In the main function, we call the 'check_isomorphism_tree' function using an if statement and pass the given parameters p and q to verify whether these integer values are isomorphic. If they are isomorphic, the print statement is "This given node information will generate an isomorphic tree", otherwise the opposite is true.
Example
is:Example
In this program, we will check whether two binary trees are isomorphic.
#include<iostream> using 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 p struct 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"<<endl; } else { cout<<" This given information of node will not make isomorphism tree "<<endl; } return 0; }
Output
This given information of node will make isomorphism tree
in conclusion
In this program, we understand the concept of isomorphism in N-ary trees. We saw how to use structures to represent tree nodes, and to build trees using left-left nodes, right-left nodes, left-right-left nodes, etc. The following operations help satisfy the isomorphic nature of trees.
The above is the detailed content of Isomorphism in N-ary trees. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

When using Notepad, we need to change the extension of Notepad due to different things we need to deal with. So how do we change the extension? In fact, we only need to use the rename function to modify the extension. How to change the extension of Win10 Notepad: 1. In the folder, first click on the top and check it. 2. In this way, the file extension will be displayed, then right-click your notepad and select 3. Select. Change the following. 4. If changed to .jpeg format. Then a prompt will pop up, click on it. 5. The change is completed, and that’s it.

Title: Specific code examples for SQL triggers to call external programs Text: When using SQL triggers, sometimes it is necessary to call external programs to process some specific operations. This article will introduce how to call external programs in SQL triggers and give specific code examples. 1. Create a trigger First, we need to create a trigger to listen for an event in the database. Here we take the "order table (order_table)" as an example. When a new order is inserted, the trigger will be activated, and then an external program will be called to perform an operation.

Title: How to convert HTML to MP4 format: Detailed code example In the daily web page production process, we often encounter the need to convert HTML pages or specific HTML elements into MP4 videos. For example, save animation effects, slideshows or other dynamic elements as video files. This article will introduce how to use HTML5 and JavaScript to convert HTML to MP4 format, and provide specific code examples. HTML5 video tag and CanvasAPI HTML5 introduction

How to grab Dump files In a computer system, a Dump file is a file that records the operating status and data of the system. In software development and system troubleshooting, grabbing Dump files can help program developers and system administrators analyze and diagnose various problems, such as program crashes, memory leaks, and system abnormalities. This article will introduce some common methods and tools to grab Dump files. 1. How to grab Dump files under Windows system using Task Manager: In Windows operating system,

Previously, win11 was officially released, and many users have already started to enjoy win12. They want to know when win12 will be released. In fact, according to the rules, it will be released around 2024. When was win12 released: A: Win12 is expected to be released around the fall of 2024. 1. According to Microsoft’s latest breaking information, win12 is expected to be released in the fall of 2024. 2. And this time win12 will have multiple new design concepts, and there will be more improvements in neatness and visual appearance. 3. At the latest developer meeting, Microsoft developers revealed that they will create a floating taskbar to give the taskbar a floating feeling.

What is the NVIDIA Control Panel? With the rapid development of computer technology, the importance of graphics cards has become more and more important. As one of the world's leading graphics card manufacturers, NVIDIA's control panel has attracted even more attention. So, what exactly does the NVIDIA control panel do? This article will give you a detailed introduction to the functions and uses of the NVIDIA control panel. First, let's understand the concept and definition of NVIDIA control panel. The NVIDIA Control Panel is a software used to manage and configure graphics card-related settings.

Mobile phone PSD files are opened using Photoshop software. PSD is Photoshop's proprietary file format and can retain information such as layers, channels, paths, transparency, etc. Therefore, if you want to open a mobile phone PSD file, first make sure you have installed Photoshop software. First, open the Photoshop software, then click the "File" option in the menu bar, and select "Open" in the pop-up drop-down menu. Next, you need to browse your folders to find the phone where you saved

Full-width and half-width are common concepts in Chinese input methods, and they represent different character widths. In the computer field, the concepts of full-width and half-width are mainly used to describe the size of space occupied by Chinese characters and English letters on the screen or in print. First of all, full-width and half-width originally originated in the era of typewriters. On typewriters, Chinese characters are usually displayed in full-width form, while English characters are displayed in half-width form. This is because Chinese characters are relatively wide, and using full-width can make the entire article look more beautiful and the layout more compact. The English characters are
