Pixie
Loading...
Searching...
No Matches
utils.h
1#pragma once
2
3#include <pixie/louds_tree.h>
4
5#include <queue>
6#include <random>
7#include <vector>
8
10
11std::vector<std::vector<size_t>> generate_random_tree(size_t tree_size,
12 std::mt19937_64& rng) {
13 if (tree_size == 0) {
14 return {};
15 }
16 std::vector<std::vector<size_t>> adj(tree_size);
17 adj[0].push_back(0);
18 for (size_t i = 1; i < tree_size; i++) {
19 size_t parent = rng() % i;
20 adj[i].push_back(parent);
21 adj[parent].push_back(i);
22 }
23 return adj;
24}
25
26std::vector<std::vector<size_t>> bfs_order(
27 size_t tree_size,
28 const std::vector<std::vector<size_t>>& adj) {
29 std::vector<std::vector<size_t>> bfs_adj(tree_size);
30 std::queue<std::pair<size_t, size_t>> q;
31 bfs_adj[0].push_back(0);
32 q.push({0, 0});
33 int cnt = 1;
34 while (!q.empty()) {
35 size_t old_v = q.front().first;
36 size_t cur_v = q.front().second;
37 q.pop();
38 for (size_t i = 1; i < adj[old_v].size(); i++) {
39 size_t old_u = adj[old_v][i];
40 size_t cur_u = cnt++;
41 q.push({old_u, cur_u});
42 bfs_adj[cur_u].push_back(cur_v);
43 bfs_adj[cur_v].push_back(cur_u);
44 }
45 }
46 return bfs_adj;
47}
48
49std::vector<std::vector<size_t>> dfs_order(
50 size_t tree_size,
51 const std::vector<std::vector<size_t>>& adj) {
52 std::vector<std::vector<size_t>> dfs_adj(tree_size);
53 std::vector<std::pair<size_t, size_t>> stack;
54 dfs_adj[0].push_back(0);
55 stack.push_back({0, 0});
56 std::vector<size_t> renumbering(tree_size, 0);
57 size_t next_number = 1;
58 while (!stack.empty()) {
59 auto& [v, i] = stack.back();
60 i++;
61 if (i == adj[v].size()) {
62 stack.pop_back();
63 continue;
64 }
65 size_t u = adj[v][i];
66 renumbering[u] = next_number++;
67 dfs_adj[renumbering[v]].push_back(renumbering[u]);
68 dfs_adj[renumbering[u]].push_back(renumbering[v]);
69
70 stack.push_back(std::pair{u, 0});
71 }
72 return dfs_adj;
73}
74
75std::vector<uint64_t> adj_to_louds(
76 size_t tree_size,
77 const std::vector<std::vector<size_t>>& adj) {
78 size_t louds_size = tree_size * 2 - 1;
79 std::vector<uint64_t> louds((louds_size + 63) / 64, 0);
80 size_t pos = 0;
81 for (size_t i = 0; i < tree_size; i++) {
82 louds[pos >> 6] = louds[pos >> 6] | (1ULL << (pos & 63));
83 pos += adj[i].size();
84 }
85 return louds;
86}
87
89 size_t number;
90};
91
92bool operator==(const AdjListNode& a, const LoudsNode& b) {
93 return a.number == b.number;
94}
95
96bool operator==(const LoudsNode& b, const AdjListNode& a) {
97 return a.number == b.number;
98}
99
101 private:
102 std::vector<std::vector<size_t>> adj;
103
104 public:
108 explicit AdjListTree(const std::vector<std::vector<size_t>>& adjacency_list)
109 : adj(adjacency_list) {}
110
114 AdjListNode root() const { return AdjListNode(0); }
115
119 bool is_leaf(const AdjListNode& node) const {
120 return adj[node.number].size() <= 1;
121 }
122
126 bool is_root(const AdjListNode& node) const { return node.number == 0; }
127
131 size_t degree(const AdjListNode& node) const {
132 return adj[node.number].size() - 1;
133 }
134
139 AdjListNode child(const AdjListNode& node, size_t i) const {
140 return AdjListNode(adj[node.number][i + 1]);
141 }
142
147 return AdjListNode(adj[node.number][1]);
148 }
149
154 AdjListNode parent(const AdjListNode& node) const {
155 return AdjListNode(adj[node.number][0]);
156 }
157
161 bool is_last_child(const AdjListNode& node) const {
162 size_t p = parent(node).number;
163 return adj[p].back() == node.number;
164 }
165
170 return AdjListNode(node.number + 1);
171 }
172};
size_t degree(const AdjListNode &node) const
Returns the number of children of node.
Definition utils.h:131
AdjListTree(const std::vector< std::vector< size_t > > &adjacency_list)
Constructor from adjacency list (root is 0)
Definition utils.h:108
AdjListNode next_sibling(const AdjListNode &node) const
Returns next sibling of a node.
Definition utils.h:169
AdjListNode first_child(const AdjListNode &node) const
Returns the first child of node.
Definition utils.h:146
AdjListNode parent(const AdjListNode &node) const
Returns the parent of a node if node is not root, else returns root.
Definition utils.h:154
AdjListNode root() const
Returns the root node.
Definition utils.h:114
AdjListNode child(const AdjListNode &node, size_t i) const
Returns the i-th child of node Indexing starts at 0.
Definition utils.h:139
bool is_root(const AdjListNode &node) const
Checks if node is a root.
Definition utils.h:126
bool is_leaf(const AdjListNode &node) const
Checks if node is a leaf.
Definition utils.h:119
bool is_last_child(const AdjListNode &node) const
Indicates if node is last child.
Definition utils.h:161
Definition utils.h:88
A node class of LOUDS tree.
Definition louds_tree.h:13