在C ++ STL中设置value_comp()函数
在本文中,我们将讨论C++STL中的set::value_comp(),它们的语法,工作原理以及它们的返回值。
C++STL中的设置是什么?
C++STL中的集合是必须按常规顺序具有唯一元素的容器。集必须具有唯一元素,因为元素的值标识该元素。一旦在集合容器中添加了值,以后就无法修改,尽管我们仍然可以删除或将值添加到集合中。集用作二进制搜索树。
设置了什么::value_comp()?
value_comp()是C++STL中的内置函数,在<set>头文件中声明。value_comp()返回比较对象的副本,设置容器将其用于比较。默认情况下,此对象小于运算符的对象。它是函数指针或函数对象的一种,它们对特定集合中相同类型的两个值进行比较,如果容器中的第一个元素小于第二个元素,则返回true,否则返回false。在集合容器中,值本身就是键,因此它们以排序的格式放置在集合容器中,因此函数value_comp()和key_comp()的工作方式类似。
语法
comparison_object set_name.value_comp();
参数
此函数不接受任何参数。
返回值
此函数返回关联的集合容器的比较对象。
示例
Input: set <int> myset = {9, 8, 7, 6, 5};
set<int>::value_compare cmp = myset.value_comp()
Output: 5 6 7 8 9示例
#include <bits/stdc++.h>
using namespace std;
int main(){
set<int> Set;
set<int>::value_compare cmp = Set.value_comp();
for (int i = 0; i <= 10; i++)
Set.insert(i);
cout<<"elements in set are: ";
int front = *Set.rbegin();
set<int>::iterator i = Set.begin();
do {
std::cout << *i << " ";
}
while (cmp(*(++i), front));
std::cout << '\n';
return 0;
}输出结果
如果我们运行上面的代码,它将生成以下输出-
elements in set are : 0 1 2 3 4 5 6 7 8 9