递归函数到迭代函数
Recursive Function to Iterative Function
//Binary Search Tree
#include <iostream>
#include "BinaryNode.h"
using namespace std;
template <class V>
class BinaryTree {
BinaryNode<V> *root;
int nodeCount;
public:
BinaryTree();
//BinaryTree(const V& newValue);
bool isEmpty() const;
int getHeight() const;
int _getHeight(BinaryNode<V>*) const;
int getNumberOfNodes() const;
V getRootData() const;
void setRootData(const V&);
bool add(const V&);
bool remove(const V&);
BinaryNode<V>* _remove(const V&, BinaryNode<V>*);
BinaryNode<V>* getInOrderSuccessor(BinaryNode<V>*);
void clear();
bool contains(const V&) const;
bool _contains(BinaryNode<V>*, const V&) const;
//print tree
void printPreorder() const;
void _printPreorder(BinaryNode<V> *curr) const;
//void printInorder() const;
//void printPostorder() const;
};
template<class V>
BinaryTree<V>::BinaryTree(){
root = nullptr;
nodeCount = 0;
}
/*
template<class V>
BinaryTree<V>::BinaryTree(const V& newValue){
root = new BinaryNode<V>(;
objCount++;
}
*/
template<class V>
bool BinaryTree<V>::isEmpty() const {
return root == nullptr;
}
template<class V>
int BinaryTree<V>::getHeight() const {
return _getHeight(root);
}
template<class V>
int BinaryTree<V>::_getHeight(BinaryNode<V>* curr) const{
if (curr != nullptr) {
int lHeight = _getHeight(curr->getLeftChildPtr());
int rHeight = _getHeight(curr->getRightChildPtr());
return ((lHeight > rHeight) ? lHeight + 1 : rHeight + 1);
}
else
return 0;
}
template<class V>
int BinaryTree<V>::getNumberOfNodes() const {
return nodeCount;
}
template<class V>
V BinaryTree<V>::getRootData() const {
if (!isEmpty()) {
return root->getValue();
}
}
template<class V>
void BinaryTree<V>::setRootData(const V& newValue) {
root->setValue(newValue);
}
template<class V>
bool BinaryTree<V>::add(const V& newValue) { // Adds a node
cout << "adding node..." << endl;
BinaryNode<V> *curr = root;
if (!isEmpty()) {
return _add(newValue, curr);
}
else {
BinaryNode<V> *temp = new BinaryNode<V>(newValue);
root = temp;
nodeCount++;
return true;
}
}
对于我的 class 作业,我们被告知采用 add 函数并将其从递归更改为迭代。有人对我如何做到这一点有任何建议吗?我们应该保持函数不变,但我们可以改变它的定义。这只是整个代码的一小段,但我认为不需要其余部分。
您可以像这样从 while 循环和 2 个指针开始:
BinaryNode<V> *curr = root;
BinaryNode<V> *prev;
if (!isEmpty()) {
while(curr) //while current is not null
{
prev=curr;
if(newValue>curr->getValue())
{
curr=curr->right;
}
else
{
curr=curr->left;
}
}
if (newValue>prev->getValue())
{
prev->right=newValue;
}
else
{
prev->left=newValue;
}
}
getValue() 函数是 getRootData() 中使用的函数,用于获取当前指向的节点的数据。
我得到了here
的帮助
此外,最好先 google 解决实际问题,如果找不到令人满意的答案,然后再 stack overflow 。
//Binary Search Tree
#include <iostream>
#include "BinaryNode.h"
using namespace std;
template <class V>
class BinaryTree {
BinaryNode<V> *root;
int nodeCount;
public:
BinaryTree();
//BinaryTree(const V& newValue);
bool isEmpty() const;
int getHeight() const;
int _getHeight(BinaryNode<V>*) const;
int getNumberOfNodes() const;
V getRootData() const;
void setRootData(const V&);
bool add(const V&);
bool remove(const V&);
BinaryNode<V>* _remove(const V&, BinaryNode<V>*);
BinaryNode<V>* getInOrderSuccessor(BinaryNode<V>*);
void clear();
bool contains(const V&) const;
bool _contains(BinaryNode<V>*, const V&) const;
//print tree
void printPreorder() const;
void _printPreorder(BinaryNode<V> *curr) const;
//void printInorder() const;
//void printPostorder() const;
};
template<class V>
BinaryTree<V>::BinaryTree(){
root = nullptr;
nodeCount = 0;
}
/*
template<class V>
BinaryTree<V>::BinaryTree(const V& newValue){
root = new BinaryNode<V>(;
objCount++;
}
*/
template<class V>
bool BinaryTree<V>::isEmpty() const {
return root == nullptr;
}
template<class V>
int BinaryTree<V>::getHeight() const {
return _getHeight(root);
}
template<class V>
int BinaryTree<V>::_getHeight(BinaryNode<V>* curr) const{
if (curr != nullptr) {
int lHeight = _getHeight(curr->getLeftChildPtr());
int rHeight = _getHeight(curr->getRightChildPtr());
return ((lHeight > rHeight) ? lHeight + 1 : rHeight + 1);
}
else
return 0;
}
template<class V>
int BinaryTree<V>::getNumberOfNodes() const {
return nodeCount;
}
template<class V>
V BinaryTree<V>::getRootData() const {
if (!isEmpty()) {
return root->getValue();
}
}
template<class V>
void BinaryTree<V>::setRootData(const V& newValue) {
root->setValue(newValue);
}
template<class V>
bool BinaryTree<V>::add(const V& newValue) { // Adds a node
cout << "adding node..." << endl;
BinaryNode<V> *curr = root;
if (!isEmpty()) {
return _add(newValue, curr);
}
else {
BinaryNode<V> *temp = new BinaryNode<V>(newValue);
root = temp;
nodeCount++;
return true;
}
}
对于我的 class 作业,我们被告知采用 add 函数并将其从递归更改为迭代。有人对我如何做到这一点有任何建议吗?我们应该保持函数不变,但我们可以改变它的定义。这只是整个代码的一小段,但我认为不需要其余部分。
您可以像这样从 while 循环和 2 个指针开始:
BinaryNode<V> *curr = root;
BinaryNode<V> *prev;
if (!isEmpty()) {
while(curr) //while current is not null
{
prev=curr;
if(newValue>curr->getValue())
{
curr=curr->right;
}
else
{
curr=curr->left;
}
}
if (newValue>prev->getValue())
{
prev->right=newValue;
}
else
{
prev->left=newValue;
}
}
getValue() 函数是 getRootData() 中使用的函数,用于获取当前指向的节点的数据。
我得到了here
的帮助此外,最好先 google 解决实际问题,如果找不到令人满意的答案,然后再 stack overflow 。