Changed from int64_t to optional<word_t> for pointers in Node
This commit is contained in:
@@ -43,7 +43,7 @@ bool Fraction::operator==(const Fraction &other)
|
|||||||
return numerator == other.numerator && denominator == other.denominator;
|
return numerator == other.numerator && denominator == other.denominator;
|
||||||
}
|
}
|
||||||
|
|
||||||
Node::Node(Fraction val, int64_t left, int64_t right)
|
Node::Node(Fraction val, index_t left, index_t right)
|
||||||
: value{val}, left{left}, right{right}
|
: value{val}, left{left}, right{right}
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
@@ -107,10 +107,13 @@ void indent_depth(int depth, std::stringstream &ss)
|
|||||||
ss << " ";
|
ss << " ";
|
||||||
}
|
}
|
||||||
|
|
||||||
std::string to_string(const NodeAllocator &allocator, const word_t n, int depth)
|
std::string to_string(const NodeAllocator &allocator, const index_t n,
|
||||||
|
int depth)
|
||||||
{
|
{
|
||||||
|
if (!n.has_value())
|
||||||
|
return "NIL";
|
||||||
std::stringstream ss;
|
std::stringstream ss;
|
||||||
Node x = allocator.vec[n];
|
Node x = allocator.getVal(n.value());
|
||||||
ss << "(" << to_string(x.value) << "\n";
|
ss << "(" << to_string(x.value) << "\n";
|
||||||
indent_depth(depth, ss);
|
indent_depth(depth, ss);
|
||||||
if (x.left == -1)
|
if (x.left == -1)
|
||||||
|
|||||||
@@ -19,6 +19,7 @@
|
|||||||
|
|
||||||
#include <cstdint>
|
#include <cstdint>
|
||||||
|
|
||||||
|
#include <optional>
|
||||||
#include <queue>
|
#include <queue>
|
||||||
#include <string>
|
#include <string>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
@@ -26,6 +27,7 @@
|
|||||||
#define MIN(A, B) ((A) < (B) ? (A) : (B))
|
#define MIN(A, B) ((A) < (B) ? (A) : (B))
|
||||||
#define MAX(A, B) ((B) < (A) ? (A) : (B))
|
#define MAX(A, B) ((B) < (A) ? (A) : (B))
|
||||||
typedef uint64_t word_t;
|
typedef uint64_t word_t;
|
||||||
|
typedef std::optional<word_t> index_t;
|
||||||
|
|
||||||
struct Fraction
|
struct Fraction
|
||||||
{
|
{
|
||||||
@@ -40,9 +42,10 @@ struct Fraction
|
|||||||
struct Node
|
struct Node
|
||||||
{
|
{
|
||||||
Fraction value;
|
Fraction value;
|
||||||
int64_t left, right;
|
index_t left, right;
|
||||||
|
|
||||||
Node(Fraction val = {}, int64_t left = -1, int64_t right = -1);
|
Node(Fraction val = {}, index_t left = std::nullopt,
|
||||||
|
index_t right = std::nullopt);
|
||||||
};
|
};
|
||||||
|
|
||||||
struct NodeAllocator
|
struct NodeAllocator
|
||||||
@@ -57,6 +60,6 @@ word_t gcd(word_t a, word_t b);
|
|||||||
Fraction iterate(std::queue<word_t> &queue, NodeAllocator &allocator);
|
Fraction iterate(std::queue<word_t> &queue, NodeAllocator &allocator);
|
||||||
|
|
||||||
std::string to_string(const Fraction &);
|
std::string to_string(const Fraction &);
|
||||||
std::string to_string(const NodeAllocator &, const word_t, int depth = 1);
|
std::string to_string(const NodeAllocator &, const index_t, int depth = 1);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|||||||
Reference in New Issue
Block a user