* fix: changed test text to use should * fix: corrected typo Co-Authored-By: Tom <20648924+moT01@users.noreply.github.com> * fix: corrected typo Co-Authored-By: Tom <20648924+moT01@users.noreply.github.com> * fix: corrected typo Co-Authored-By: Tom <20648924+moT01@users.noreply.github.com> * fix: use singular of verb Co-Authored-By: Tom <20648924+moT01@users.noreply.github.com> * fix: changed punctuation Co-Authored-By: Tom <20648924+moT01@users.noreply.github.com> * fix: reworded test text Co-Authored-By: Tom <20648924+moT01@users.noreply.github.com>
143 lines
4.7 KiB
Markdown
143 lines
4.7 KiB
Markdown
---
|
|
id: 587d8259367417b2b2512c83
|
|
title: Invert a Binary Tree
|
|
challengeType: 1
|
|
forumTopicId: 301704
|
|
---
|
|
|
|
## Description
|
|
<section id='description'>
|
|
Here will we create a function to invert a binary tree. Given a binary tree, we want to produce a new tree that is equivalently the mirror image of this tree. Running an inorder traversal on an inverted tree will explore the nodes in reverse order when compared to the inorder traversal of the original tree. Write a method to do this called <code>invert</code> on our binary tree. Calling this method should invert the current tree structure. Ideally, we would like to do this in-place in linear time. That is, we only visit each node once and we modify the existing tree structure as we go, without using any additional memory. Good luck!
|
|
</section>
|
|
|
|
## Instructions
|
|
<section id='instructions'>
|
|
|
|
</section>
|
|
|
|
## Tests
|
|
<section id='tests'>
|
|
|
|
```yml
|
|
tests:
|
|
- text: The <code>BinarySearchTree</code> data structure should exist.
|
|
testString: assert((function() { var test = false; if (typeof BinarySearchTree !== 'undefined') { test = new BinarySearchTree() }; return (typeof test == 'object')})());
|
|
- text: The binary search tree should have a method called <code>invert</code>.
|
|
testString: assert((function() { var test = false; if (typeof BinarySearchTree !== 'undefined') { test = new BinarySearchTree() } else { return false; }; return (typeof test.invert == 'function')})());
|
|
- text: The <code>invert</code> method should correctly invert the tree structure.
|
|
testString: assert((function() { var test = false; if (typeof BinarySearchTree !== 'undefined') { test = new BinarySearchTree() } else { return false; }; if (typeof test.invert !== 'function') { return false; }; test.add(4); test.add(1); test.add(7); test.add(87); test.add(34); test.add(45); test.add(73); test.add(8); test.invert(); return test.inorder().join('') == '877345348741'; })());
|
|
- text: Inverting an empty tree should return <code>null</code>.
|
|
testString: assert((function() { var test = false; if (typeof BinarySearchTree !== 'undefined') { test = new BinarySearchTree() } else { return false; }; if (typeof test.invert !== 'function') { return false; }; return (test.invert() == null); })());
|
|
|
|
```
|
|
|
|
</section>
|
|
|
|
## Challenge Seed
|
|
<section id='challengeSeed'>
|
|
<div id='js-seed'>
|
|
|
|
```js
|
|
var displayTree = (tree) => console.log(JSON.stringify(tree, null, 2));
|
|
function Node(value) {
|
|
this.value = value;
|
|
this.left = null;
|
|
this.right = null;
|
|
}
|
|
function BinarySearchTree() {
|
|
this.root = null;
|
|
// change code below this line
|
|
// change code above this line
|
|
}
|
|
```
|
|
|
|
</div>
|
|
|
|
|
|
### After Test
|
|
<div id='js-teardown'>
|
|
|
|
```js
|
|
BinarySearchTree.prototype = {
|
|
add: function(value) {
|
|
var node = this.root;
|
|
if (node == null) {
|
|
this.root = new Node(value);
|
|
return;
|
|
} else {
|
|
function searchTree(node) {
|
|
if (value < node.value) {
|
|
if (node.left == null) {
|
|
node.left = new Node(value);
|
|
return;
|
|
} else if (node.left != null) {
|
|
return searchTree(node.left)
|
|
};
|
|
} else if (value > node.value) {
|
|
if (node.right == null) {
|
|
node.right = new Node(value);
|
|
return;
|
|
} else if (node.right != null) {
|
|
return searchTree(node.right);
|
|
};
|
|
} else {
|
|
return null;
|
|
};
|
|
};
|
|
return searchTree(node);
|
|
};
|
|
},
|
|
inorder: function() {
|
|
if (this.root == null) {
|
|
return null;
|
|
} else {
|
|
var result = new Array();
|
|
function traverseInOrder(node) {
|
|
if (node.left != null) {
|
|
traverseInOrder(node.left);
|
|
};
|
|
result.push(node.value);
|
|
if (node.right != null) {
|
|
traverseInOrder(node.right);
|
|
};
|
|
}
|
|
traverseInOrder(this.root);
|
|
return result;
|
|
};
|
|
}
|
|
};
|
|
```
|
|
|
|
</div>
|
|
</section>
|
|
|
|
## Solution
|
|
<section id='solution'>
|
|
|
|
```js
|
|
var displayTree = (tree) => console.log(JSON.stringify(tree, null, 2));
|
|
function Node(value) {
|
|
this.value = value;
|
|
this.left = null;
|
|
this.right = null;
|
|
}
|
|
function BinarySearchTree() {
|
|
this.root = null;
|
|
// change code below this line
|
|
this.invert = function(node = this.root) {
|
|
if (node) {
|
|
const temp = node.left;
|
|
node.left = node.right;
|
|
node.right = temp;
|
|
this.invert(node.left);
|
|
this.invert(node.right);
|
|
}
|
|
return node;
|
|
}
|
|
// change code above this line
|
|
}
|
|
|
|
```
|
|
|
|
</section>
|