簡體   English   中英

創建一個 C++ 預排序迭代器來為循環提供樹節點

[英]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.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM