基于以下问题:Check if one string is a rotation of other string
我在考虑做一个带范围的循环迭代器类型,可以像这样解决上面的问题:
std::string s1 = "abc" ;
std::string s2 = "bca" ;
std::size_t n = 2; // number of cycles
cyclic_iterator it(s2.begin(),s2.end(),n);
cyclic_iterator end;
if (std::search(it, end, s1.begin(),s1.end()) != end)
{
std::cout << "s1 is a rotation of s2" << std::endl;
}
我的问题是,已经有类似的东西可用了吗?我已经检查了Boost和STL,它们都没有确切的实现。
我有一个简单的手写版本(从std::iterator
的std::forward_iterator_tag
专用版派生而来),但我更愿意使用已经制作/测试的实现。
https://stackoverflow.com/questions/2616643
复制相似问题