- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我正在尝试使用排序函数对字符串进行排序:这是一个字符串:索引从零
开始"effort"
我的目标是从索引 (1 到 4)[n=1,m=4] 中按降序排序,即生成一个字符串:
"erofft"
我使用函数排序为:
sort( str.rbegin()+ (str.length()-1-m) , str.rbegin()+ (str.length()-1-n) );
但这似乎不起作用:我想我很难理解 rbegin() 迭代器。
最佳答案
我认为为此使用 rbegin
毫无意义。您只需要一个带有自定义比较器的排序:
std::sort(str.begin() + 1, str.begin() + 5, [](auto l, auto r) {
using Trait = std::remove_reference_t<decltype(str)>::traits_type;
return !Trait::lt(l, r) && !Trait::eq(l, r);
});
上面的一点解释:
对于标准库中的所有范围,末尾是唯一的,因此我们需要在 [1, 5)
范围内排序。
sort
有一个接受自定义比较器的重载。这个自定义比较器决定两个元素中谁先出现。我们为此使用 lambda。
要决定哪个元素先出现,我们可以只做 l > r
,但那不是正确的方法。 std::basic_string
有一个 traits 模板参数,它决定如何比较和排序字符串。它可以具有使字符串不区分大小写的自定义特征。我的版本正确地使用了它。
关于c++ - 如何在排序函数中使用 rbegin()?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53922345/
我在使用这段代码的 C++ 中遇到了一个奇怪的问题: mutex_type list_mutex; typedef list RQueue; RQueue rQueue; RQueue::rever
我正在尝试使用排序函数对字符串进行排序:这是一个字符串:索引从零开始 "effort" 我的目标是从索引 (1 到 4)[n=1,m=4] 中按降序排序,即生成一个字符串: "erofft" 我使用函
在下图中,我正在使用相同类型的迭代器,这意味着相同的operator ++实现,因此编译器如何知道应获取下一个值还是前一个值...? 最佳答案 首先,您的图片包含错误。如您所见here, vector
下面函数中rbegin()和rend()判断输入是否回文的具体作用是什么? bool palindromeCheck(string input) { if (input == string(i
我需要从容器的开头迭代到结尾之前的一个元素。我可以在循环中放置一个 if 条件来绕过最后一个元素,但我想知道是否可以像这样编写 for 循环: for (it = C.begin(); it != C
我重构了一个使用单个元素列表的类,因此它现在使用这样的列表的列表。为了尽量减少派生类的变化,我实现了一个自定义 iterator使用 boost::iterator_facade还有一种获取 boos
运行下面的代码,我希望看到测试 1 的第 4 个值的不同地址(与值 1 和 3 不同)。这表明 rend() 与 rbegin() 相同??我也不希望循环经历第二次迭代并出现段错误。 知道我做错了什么
为什么下面的代码会崩溃? int main(int argc, const char * argv[]) { std::list aList={1,2,3,4,5}; std::list::rever
我想知道使用 rbegin() 而不是 end() - 1 对 STL 容器有什么好处。 例如,你为什么要使用这样的东西: vector v; v.push_back(999); vector::re
我有一些名为 Order 的类。由于某些原因,以下代码在使用 rbegin() 时无法编译,但它适用于 begin()。我声明迭代器的方式有问题还是我的指针引用有问题? map> m typedef
既然在 C++11 修订版中为标准包含添加了非成员 begin() 和 end() 函数,为什么会有非成员版本的 rbegin() 和 rend() 函数也没有添加?开始使用begin()和end()
这个问题已经有答案了: How to call erase with a reverse iterator (14 个回答) 已关闭 3 年前。 社区去年审查了是否重新开放此问题,并将其关闭: 原始关
下面是我的 String 类的代码。我想实现 reverse_iterator 和 rbegin() 和 rend() 方法。已粘贴分配方法的代码。 String::reverse_iterator
我正在使用 boost::tokenizer,但我意识到它不支持 rbegin() 和 rend()。我想请问如何将这两个功能添加到现有类中? 这是来自 boost 网站: #include #in
根据我发现的一些 STL 文档,在 std::list 中插入或删除元素不会使迭代器无效。这意味着它可以遍历一个列表(从 begin() 到 end()),然后使用 push_front 添加元素。
对于 std::set 和 std::map 等以对数时间查找的数据类型,实现是否需要维护开始和结束迭代器?访问 begin 和 end 是否意味着查找可能以对数时间发生? 我一直假设开始和结束总是在
我遇到了一个特殊问题,我的团队担心使用 std::chrono。 我们正在使用 MSVS-13,所以是 C++11。 我有一组对象状态存储在多映射中,以 std:chrono::millisecond
我一直在 MSVC 2013 中使用 std::rbegin 和 std::rend。当我尝试使用 GCC 4.9.1 或 clang 3.5.0 编译我的代码时,两者都告诉我“rbegin”和“re
我是一名优秀的程序员,十分优秀!