作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我已经编写了两种打印链表数据的方法。一种是正常工作的打印。一种是以相反的顺序打印列表。我想让我的打印方法接受 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);
题外话:
#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/
我来自 Asp.Net 世界,试图理解 Angular State 的含义。 什么是 Angular 状态?它类似于Asp.Net中的ascx组件吗?是子页面吗?它类似于工作流程状态吗? 我听到很多人
我一直在寻找 3 态拨动开关,但运气不佳。 基本上我需要一个具有以下状态的开关: |开 |不适用 |关 | slider 默认从中间开始,一旦用户向左或向右滑动,就无法回到N/A(未回答)状态。 有人
我是一名优秀的程序员,十分优秀!