gpt4 book ai didi

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

转载 作者:行者123 更新时间:2023-11-30 05:36:30 25 4
gpt4 key购买 nike

我已经编写了两种打印链表数据的方法。一种是正常工作的打印。一种是以相反的顺序打印列表。我想让我的打印方法接受 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/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com