Table of Contents
grammar
parameter
algorithm
Example
Output
in conclusion
Home Backend Development C++ Isomorphism in N-ary trees

Isomorphism in N-ary trees

Sep 15, 2023 am 09:01 AM
Programming keywords n-ary tree isomorphism

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-

Isomorphism in N-ary trees

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

Isomorphism in N-ary trees

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.
}
Copy after login

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.

The Chinese translation of

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;
}
Copy after login

Output

This given information of node will make isomorphism tree
Copy after login

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!

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
2 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: How To Get Giant Seeds
1 months ago By 尊渡假赌尊渡假赌尊渡假赌
Two Point Museum: All Exhibits And Where To Find Them
1 months ago By 尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

How to change the file extension of Win10 Notepad How to change the file extension of Win10 Notepad Jan 04, 2024 pm 12:49 PM

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.

Call SQL trigger to execute external program Call SQL trigger to execute external program Feb 18, 2024 am 10:25 AM

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.

How to convert HTML to MP4 format How to convert HTML to MP4 format Feb 19, 2024 pm 02:48 PM

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 extract Dump files How to extract Dump files Feb 19, 2024 pm 12:15 PM

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,

Windows 12 release date Windows 12 release date Jan 05, 2024 pm 05:24 PM

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 role of the NVIDIA Control Panel? What is the role of the NVIDIA Control Panel? Feb 19, 2024 pm 03:59 PM

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.

How to open psd files on mobile phone How to open psd files on mobile phone Feb 21, 2024 pm 05:48 PM

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

The role of full-width and half-width in Chinese input method The role of full-width and half-width in Chinese input method Mar 25, 2024 am 09:57 AM

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

See all articles