C++ std::set如何实现自定义排序

   2024-10-11 6480
核心提示:要在std::set中实现自定义排序,可以使用自定义的比较函数或仿函数来定义元素的排序规则。以下是一个示例代码,演示了如何使用自

要在std::set中实现自定义排序,可以使用自定义的比较函数或仿函数来定义元素的排序规则。以下是一个示例代码,演示了如何使用自定义比较函数来对set中的元素进行排序:

#include <iostream>#include <set>// 自定义比较函数,按照元素的绝对值大小进行排序struct Compare {    bool operator()(const int& a, const int& b) const {        return std::abs(a) < std::abs(b);    }};int main() {    std::set<int, Compare> mySet;    mySet.insert(5);    mySet.insert(-3);    mySet.insert(2);    mySet.insert(-1);    for (const auto& val : mySet) {        std::cout << val << " ";    }    return 0;}

在这个示例中,我们定义了一个自定义的比较函数Compare,它按照元素的绝对值大小进行排序。然后在声明set对象时,指定了自定义的比较函数Compare作为第二个模板参数。这样就可以在set中使用自定义的比较函数来对元素进行排序。

 
举报打赏
 
更多>同类维修大全
推荐图文
推荐维修大全
点击排行

网站首页  |  关于我们  |  联系方式网站留言    |  赣ICP备2021007278号