Algorithms_in_C++ 1.0.0
Set of algorithms implemented in C++.
Loading...
Searching...
No Matches
reverse_binary_tree.cpp File Reference

Implementation for the Reversing a Binary Tree recursively algorithm. More...

#include <cassert>
#include <iostream>
#include <queue>
#include <vector>
Include dependency graph for reverse_binary_tree.cpp:

Classes

struct  operations_on_datastructures::reverse_binary_tree::Node
 A Node struct that represents a single node in a Binary Tree. More...
 
class  operations_on_datastructures::reverse_binary_tree::BinaryTree
 A Binary Tree class that implements a Binary Search Tree (BST) by default. More...
 

Namespaces

namespace  operations_on_datastructures
 for std::vector
 
namespace  reverse_binary_tree
 Functions for the Reverse a Binary Tree implementation.
 
namespace  tests
 Testcases to check Union of Two Arrays.
 

Functions

void tests::test1 ()
 A Test to check an simple case.
 
void tests::test2 ()
 A Test to check an empty vector.
 
void tests::test3 ()
 A Test to check an invalid shift value.
 
static void test ()
 Function to test the correctness of the Tree Reversal.
 
int main ()
 main function
 

Detailed Description

Implementation for the Reversing a Binary Tree recursively algorithm.

A binary tree can be reversed by swapping the left and right child of a node at each node, starting from the root, and cascading below. This solution aims to provide an implementation of a recursive reversal of a binary tree.

Author
Alvin

Function Documentation

◆ main()

int main ( void )

main function

Returns
0 on exit
270 {
271 test(); // run self-test implementations
272 return 0;
273}
static void test()
Function to test the correctness of the Tree Reversal.
Definition reverse_binary_tree.cpp:260
Here is the call graph for this function:

◆ test()

static void test ( )
static

Function to test the correctness of the Tree Reversal.

< Single element test

< No element test

< Correct reversal test

260 {
261 tests::test1(); ///< Single element test
262 tests::test2(); ///< No element test
263 tests::test3(); ///< Correct reversal test
264}
void test1()
A Test to check an simple case.
Definition array_left_rotation.cpp:75
void test3()
A Test to check an invalid shift value.
Definition array_left_rotation.cpp:105
void test2()
A Test to check an empty vector.
Definition array_left_rotation.cpp:90
Here is the call graph for this function: