[英]Create a C++ preorder iterator to supply tree nodes to a loop
我正在嘗試編寫一個 C++ 程序來為這個循環提供樹節點:
bin_tree<int> *my_tree = ...
for (bin_tree<int>::iterator n = my_tree->begin();
n != my_tree->end(); ++n)
{
cout << *n << "\n";
}
我的課程是用 Java 編寫的,我想將它翻譯成 C++,但是我在這樣做時遇到了麻煩。 這是課程:
class BinTree<T> implements Iterable<T> {
BinTree<T> left;
BinTree<T> right;
T val;
// other methods: insert, delete, lookup, ...
public Iterator<T> iterator()
{
return new TreeIterator(this);
}
private class TreeIterator implements Iterator<T>
{
private Stack<BinTree<T>> s = new Stack<BinTree<T>>();
TreeIterator(BinTree<T> n)
{
if (n.val != null) s.push(n);
}
public boolean hasNext()
{
return !s.empty();
}
public T next()
{
if (!hasNext()) throw new NoSuchElementException();
BinTree<T> n = s.pop();
if (n.right != null) s.push(n.right);
if (n.left != null) s.push(n.left);
return n.val;
}
public void remove()
{
throw new UnsupportedOperationException();
}
}
}
任何有關如何在 C++ 中正確編寫此程序的幫助將不勝感激,我不確定如何正確實現預序迭代器。
如果您正在嘗試創建一個支持迭代器的容器,我會建議以下內容(您可能知道所有這些,但它可能會幫助您編寫好的 C++):
了解迭代器(在您的情況下,擁有雙向迭代器可能是有意義的)。 迭代器是 C++ 中指針的包裝器。
了解你想要的底層數據結構(二叉樹還是二叉搜索樹?)。
迭代器應該如何遍歷樹? (前序、中序、后序或級序)
我的方法是編寫我自己的節點類/結構。 然后編寫一個迭代器類來處理指針操作。 如果您需要以某種方式處理分配,我也會編寫一個自定義分配器來提供幫助。 最后編寫使用其他類的容器。 (模塊化並以在 C++ 中易於理解的方式分離功能)
如果您只是在尋找迭代器邏輯並擁有您需要的一切; begin 是第一個地址,例如可以包裝為 &data [0] 。 End 是類似方式的最后一個地址。 ++ 運算符在指針上受支持,並將沿直線向終點移動。 仍然會想弄清楚移動樹應該有效! 甚至可以提供多種方式。
祝你好運!
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.