bump
parent
0f93988fb6
commit
038cbb73f4
@ -0,0 +1,42 @@
|
||||
#pragma once
|
||||
#include <stack>
|
||||
|
||||
#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 : BaseIterator<T>::current->children())
|
||||
q.push(it.get());
|
||||
}
|
||||
|
||||
IIterator<T>& operator++() override {
|
||||
advance();
|
||||
return *this;
|
||||
}
|
||||
|
||||
virtual size_t level() const {
|
||||
return level_;
|
||||
}
|
||||
|
||||
protected:
|
||||
std::queue<T*> q;
|
||||
size_t level_;
|
||||
|
||||
void advance() {
|
||||
if (q.empty()) {
|
||||
this->current = nullptr;
|
||||
return;
|
||||
}
|
||||
|
||||
this->current = q.front();
|
||||
q.pop();
|
||||
|
||||
for (auto& it : this->current->children())
|
||||
q.push(it.get());
|
||||
}
|
||||
};
|
||||
@ -0,0 +1,22 @@
|
||||
#pragma once
|
||||
#include <queue>
|
||||
|
||||
#include "ifaces/INode.h"
|
||||
|
||||
#include "iterators/DFSIterator.h"
|
||||
#include "iterators/BFSIterator.h"
|
||||
|
||||
template<typename Policy>
|
||||
class Traversal {
|
||||
INode* start;
|
||||
|
||||
public:
|
||||
explicit Traversal(INode* start) : start(start) {}
|
||||
explicit Traversal(NodePtr start) : start(start.get()) {}
|
||||
|
||||
Policy begin() const { return Policy(start); }
|
||||
Policy end() const { return Policy(nullptr); }
|
||||
};
|
||||
|
||||
using TraversalDFS = Traversal<DFSIterator<INode>>;
|
||||
using TraversalBFS = Traversal<BFSIterator<INode>>;
|
||||
Loading…
Reference in New Issue