递归 - >迭代
Recursion -> Iteration
带有以下trie结构:
struct Trie{
char letter;
bool eow;
Trie *letters[26];
};
我正在使用以下代码以字母顺序从trie中提取矢量的单词。
void getWords(const TrieNode& data, vector<string> &words, string acc)
{
if (data.eow)
words.push_back(acc);
for (int i = 0; i < 26; i++) {
if (data.letters[i] != NULL)
getWords(*(data.letters[i]), words, acc + data.letters[i]->letter);
}
}
我只是想知道是否有没有递归而只使用迭代的方法?我正在尝试仅使用迭代来实现此功能,但无法想到一种使用循环检查Trie中每一层的每一层字母的方法。有任何建议吗?
struct State {
const TrieNode* data;
string acc;
int index;
State( ... ): ... {} // element-wise constructor, left as an exercise
};
std::vector<string> getWords( const TrieNode* root )
{
std::vector<string> retval;
std::vector<State> states;
states.push_back( State( root, string(), 0 ) );
while (!states.empty())
{
State s = states.back();
states.pop_back();
if (s.data->eow)
{
retval.push_back( s.acc );
continue;
}
if (s.index >= 26)
continue;
states.push_back( State( s.data, s.acc, s.index+1 ) );
if (s.letters[s.index])
{
states.push_back( State( s.letters[s.index], s.acc + s.letters[s.index]->letter, 0 ) );
}
}
return std::move(retval);
};
状态是一个明确的堆栈,它几乎可以跟踪与您递归跟踪相同的数据。我想我设法以相同的顺序访问了元素,这并不重要。
请注意,上述代码是编写的,未测试,您必须为状态编写一个元素构造函数,因为我很懒惰。
相关文章:
- 使用std::multimap迭代器创建std::list
- 来自 std::list 的迭代器 .end() 按预期返回"0xcdcdcdcdcdcdcdcd"但 .begin()
- C++中带有List类的迭代器Segfault
- 迭代时从向量和内存中删除对象
- 如何在c++迭代器类型中包装std::chrono
- 带过滤器的现代迭代c++集合
- 在c++中检查长方体是否尽可能快地重叠(无迭代)
- C++矢量迭代
- 集合上的输出迭代器:assign和increment迭代器
- Boost Spirit,获取迭代器内部语义动作
- 擦除while循环中迭代的元素
- 实现一个在集合上迭代的模板函数
- 对于set上的循环-获取next元素迭代器
- 在向量内的向量上迭代
- 为什么output_editor Concept不需要output_e迭代器标记
- TSP递归解的迭代形式
- c++17文件系统::recursive_directory迭代器()在mac上没有给出这样的目录,但在windows上
- 使用迭代器时如何访问对象在向量中的位置?
- std::vector::迭代器是否可以合法地作为指针
- 跟随整数索引列表的自定义类迭代器