3#include <pixie/louds_tree.h>
11std::vector<std::vector<size_t>> generate_random_tree(
size_t tree_size,
12 std::mt19937_64& rng) {
16 std::vector<std::vector<size_t>> adj(tree_size);
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);
26std::vector<std::vector<size_t>> bfs_order(
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);
35 size_t old_v = q.front().first;
36 size_t cur_v = q.front().second;
38 for (
size_t i = 1; i < adj[old_v].size(); i++) {
39 size_t old_u = adj[old_v][i];
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);
49std::vector<std::vector<size_t>> dfs_order(
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();
61 if (i == adj[v].size()) {
66 renumbering[u] = next_number++;
67 dfs_adj[renumbering[v]].push_back(renumbering[u]);
68 dfs_adj[renumbering[u]].push_back(renumbering[v]);
70 stack.push_back(std::pair{u, 0});
75std::vector<uint64_t> adj_to_louds(
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);
81 for (
size_t i = 0; i < tree_size; i++) {
82 louds[pos >> 6] = louds[pos >> 6] | (1ULL << (pos & 63));
93 return a.number == b.number;
97 return a.number == b.number;
102 std::vector<std::vector<size_t>> adj;
108 explicit AdjListTree(
const std::vector<std::vector<size_t>>& adjacency_list)
109 : adj(adjacency_list) {}
120 return adj[node.number].size() <= 1;
132 return adj[node.number].size() - 1;
162 size_t p =
parent(node).number;
163 return adj[p].back() == node.number;
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
A node class of LOUDS tree.
Definition louds_tree.h:13