add iterators
New iterators can be used to iterate through Nodes.
Squashed commit of the following:
commit 602ed679631647dd1c8874b0b0145fcb09458341
Author: GRayHook <s@marinkevich.ru>
Date: Fri Aug 1 19:36:46 2025 +0700
fup after CR
commit 08f7b59aa7
Author: GRayHook <s@marinkevich.ru>
Date: Fri Aug 1 19:20:48 2025 +0700
normalize members of iterator
commit 038cbb73f4
Author: GRayHook <s@marinkevich.ru>
Date: Fri Aug 1 18:57:08 2025 +0700
bump
commit 0f93988fb6
Author: GRayHook <s@marinkevich.ru>
Date: Fri Aug 1 11:32:35 2025 +0700
tmp
master
parent
0f9d73366b
commit
f46e1a6d0b
@ -0,0 +1,21 @@
|
|||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include "iterators/BaseIterator.h"
|
||||||
|
|
||||||
|
template <typename T>
|
||||||
|
struct IteratorForward : public BaseIterator<T> {
|
||||||
|
explicit IteratorForward(T* ptr) : Iterator<T>(first(ptr)) {}
|
||||||
|
|
||||||
|
static T* first(T* node) {
|
||||||
|
return node;
|
||||||
|
}
|
||||||
|
|
||||||
|
static T* next(T* node) {
|
||||||
|
return node ? node->get_next() : nullptr;
|
||||||
|
}
|
||||||
|
|
||||||
|
Iterator<T>& operator++() override {
|
||||||
|
this->current = next(this->current);
|
||||||
|
return *this;
|
||||||
|
}
|
||||||
|
};
|
||||||
@ -0,0 +1,14 @@
|
|||||||
|
#pragma once
|
||||||
|
|
||||||
|
/// \brief Интерфейс для классов-итераторов.
|
||||||
|
/// \tparam T Тип итерируемого элемента.
|
||||||
|
template <typename T>
|
||||||
|
class IIterator {
|
||||||
|
public:
|
||||||
|
virtual T* operator->() const = 0;
|
||||||
|
virtual operator const T*() const = 0;
|
||||||
|
|
||||||
|
virtual bool operator!=(const IIterator& other) const = 0;
|
||||||
|
|
||||||
|
virtual IIterator& operator++() = 0;
|
||||||
|
};
|
||||||
@ -0,0 +1,40 @@
|
|||||||
|
#pragma once
|
||||||
|
#include <queue>
|
||||||
|
|
||||||
|
#include "iterators/BaseIterator.h"
|
||||||
|
|
||||||
|
template <typename T>
|
||||||
|
class BFSIterator : public BaseIterator<T> {
|
||||||
|
public:
|
||||||
|
explicit BFSIterator(T* ptr) : BaseIterator<T>(ptr) {
|
||||||
|
if (!this->current())
|
||||||
|
return;
|
||||||
|
|
||||||
|
for (auto& it : this->current()->children())
|
||||||
|
q.push({it.get(), 1});
|
||||||
|
}
|
||||||
|
|
||||||
|
IIterator<T>& operator++() override {
|
||||||
|
advance();
|
||||||
|
return *this;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected:
|
||||||
|
std::queue<std::pair<T*, size_t>> q;
|
||||||
|
|
||||||
|
void advance() {
|
||||||
|
if (q.empty()) {
|
||||||
|
this->set_current(nullptr);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
auto& [node, lvl] = q.front();
|
||||||
|
q.pop();
|
||||||
|
|
||||||
|
this->set_current(node);
|
||||||
|
this->set_level(lvl);
|
||||||
|
|
||||||
|
for (auto& it : this->current()->children())
|
||||||
|
q.push({it.get(), lvl + 1});
|
||||||
|
}
|
||||||
|
};
|
||||||
@ -0,0 +1,43 @@
|
|||||||
|
#pragma once
|
||||||
|
#include <stack>
|
||||||
|
#include <iterator>
|
||||||
|
|
||||||
|
#include "iterators/BaseIterator.h"
|
||||||
|
|
||||||
|
template <typename T>
|
||||||
|
class DFSIterator : public BaseIterator<T> {
|
||||||
|
public:
|
||||||
|
explicit DFSIterator(T* ptr) : BaseIterator<T>(ptr) {
|
||||||
|
if (!this->current())
|
||||||
|
return;
|
||||||
|
|
||||||
|
for (auto it = this->current()->children().rbegin();
|
||||||
|
it != this->current()->children().rend(); ++it)
|
||||||
|
s.push({it->get(), 1});
|
||||||
|
}
|
||||||
|
|
||||||
|
IIterator<T>& operator++() override {
|
||||||
|
advance();
|
||||||
|
return *this;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected:
|
||||||
|
std::stack<std::pair<T*, size_t>> s;
|
||||||
|
|
||||||
|
void advance() {
|
||||||
|
if (s.empty()) {
|
||||||
|
this->set_current(nullptr);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
auto [node, lvl] = s.top();
|
||||||
|
s.pop();
|
||||||
|
|
||||||
|
this->set_current(node);
|
||||||
|
this->set_level(lvl);
|
||||||
|
|
||||||
|
for (auto it = this->current()->children().rbegin();
|
||||||
|
it != this->current()->children().rend(); ++it)
|
||||||
|
s.push({it->get(), lvl + 1});
|
||||||
|
}
|
||||||
|
};
|
||||||
Loading…
Reference in New Issue