c++ - 用于在单个类中使用 C++ 打印和反转打印的多态函数

标签 c++ polymorphism operator-overloading

我已经编写了两种打印链表数据的方法。一种是正常工作的打印。一种是以相反的顺序打印列表。我想让我的打印方法接受 Node* ptr 并像往常一样完成其余工作。由于运算符重载,我不知道如何让它工作。我的方法如下。请忽略 reversePrint 方法中的 void* 转换和返回。

template <class T>
    std::ostream& operator <<(std::ostream& str, LinkedList<T> const& data){
        data.print(str);
        return str;
    }

    template <class T>
    void LinkedList<T>::print(std::ostream& str) const{
        Node *curr = head;
        while(curr != nullptr){
            str << curr->data << "\n";
            curr = curr->next;
        }

    }

    template <class T>
    void* LinkedList<T>::printReverse(std::ostream& str) {
        Node* curr = head;
        //Node* last = (Node*)getLastNode(head);
        Node* rHead = nullptr;

        while(curr != nullptr){
            Node* temp = curr->next;
            curr->next = rHead;
            rHead = curr;
            curr = temp;
        }

        while(rHead != nullptr){
                std::cout << rHead->data << "\n";
                rHead = rHead->next;
            }
        return (void*)rHead; 
    }

类定义。

template <class T>
class LinkedList {

private:
    struct Node {
        T data;
        Node *next;

        Node(T data, Node *next) :
                data(data), next(next) {
        }

    };
    Node* head;

public:
    LinkedList() :
            head(nullptr) {
    }

    ~LinkedList() {
        Node *temp;
        for (; head; head = temp) {
            temp = head->next;
            std::cout << "Destructor called for " << temp->data;
            delete head;
            }
    }

    void append(T item);
    void insert_at_head(T value);
    void* getLastNode(Node* n);
    void print(std::ostream& str = std::cout) const;
    void* printReverse(std::ostream& str = std::cout);

};

最佳答案

printReverse 可能应该修改列表。

我会递归地写它。想法:

template <class T> void LinkedList<T>::printReverse(std::ostream &str, Node const* head) {
    if (!head) return;
    printReverse(str, head->next);
    std::cout << head->data << "\n";
}

例如类声明:

    void printReverse(std::ostream &str) const { printReverse(str, head); }
  private:
    void static printReverse(std::ostream &str, Node const* head);

题外话:

  • 考虑常量正确性
  • 考虑命令/查询分离(将节点迭代与打印分开)

Live On Coliru

#include <iostream>
template <class T> class LinkedList {

  private:
    struct Node {
        T data;
        Node *next;
        //Node(T data, Node *next) : data(data), next(next) {}
    };
    Node *head;

  public:
    LinkedList() : head(nullptr) {}

    ~LinkedList() {
        while (head) {
            Node* temp = head->next;
            std::cout << "Destructor called for " << head->data;
            delete head;
            head = temp;
        }
    }

    void append(T item) {
        Node* t = getLastNode(head);
        (t?t->next : head) = new Node { item, nullptr };
    }

    void insert_at_head(T value);

    Node const*getLastNode(Node const*n) const {
        for (Node const* it = n; it; it = it->next)
            if (!it->next) return it;
        return nullptr;
    }

    Node*getLastNode(Node*n) {
        for (Node* it = n; it; it = it->next)
            if (!it->next) return it;
        return nullptr;
    }

    void print(std::ostream &str = std::cout) const;
    void printReverse(std::ostream &str) const { printReverse(str, head); }
  private:
    void static printReverse(std::ostream &str, Node const* head);
};

template <class T> std::ostream &operator<<(std::ostream &str, LinkedList<T> const &data) {
    data.print(str);
    return str;
}

template <class T> void LinkedList<T>::print(std::ostream &str) const {
    for (Node const* curr=head; curr; curr = curr->next) {
        str << curr->data << "\n";
    }
}

template <class T> void LinkedList<T>::printReverse(std::ostream &str, Node const* head) {
    if (!head) return;
    printReverse(str, head->next);
    std::cout << head->data << "\n";
}

int main() {
    LinkedList<int> ll;
    ll.append(1);
    ll.append(2);
    ll.append(3);
    ll.append(4);

    ll.print(std::cout);
    ll.printReverse(std::cout);
}

打印

1
2
3
4
4
3
2
1

关于c++ - 用于在单个类中使用 C++ 打印和反转打印的多态函数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33542284/

相关文章:

c++ - 静态库单独使用没问题,但在被引用时会抛出错误

c++ - 调用已在另一个函数中初始化的类

c++ - 是否可以在 C++ 中进行多态成员重载?

c++ - C++ 中指针的运行时多态性

c++ - 用于右值和左值情况的 [] 运算符的两个版本

c++ - 比较运算符重载,为什么编译器不做这项工作?

c++ - 如何解码SIP数据包?

c++ - Clang:将引用绑定(bind)到类型为 'const TClass' 的值会删除限定符

c++ - 将派生类转换为基类

c++ - 重载运算符 <<