stl自定义的比较器主要用于实现容器中元素的比较。比较器的定义的方式主要有下面三种:
对vector数值进行降序排序
sort默认是升序的,这里通过cmp函数改成降序排序。如果将cmp的返回值改成a
bool cmp(int a, int b) {
return a > b;
}
int main() {
std::vector<int> data {1, 6, 3, 5, 9 ,20};
std::sort(data.begin(), data.end(), cmp);
for_each(data.begin(), data.end(), [](int i){std::cout << i << std::endl; });
return 0;
}
对vector字符串进行反字典排序
sort默认是字典序的,这里通过cmp函数改成降序排序。如果将cmp的返回值改成a
bool cmp(std::string a, std::string b) {
return a > b;
}
int main() {
std::vector<std::string> name_list{"zhoujielun", "linjunjie", "axin", "xiaojingteng"};
std::sort(name_list.begin(), name_list.end(), cmp);
for_each(name_list.begin(), name_list.end(), [](std::string i){std::cout << i << std::endl; });
return 0;
}
2.定义全局的operator<
适用于一些自定义的类型,根据其中一个属性进行排序
例如将根据同学的分数,降序排列
struct Person{
Person(std::string name, float score)
:name_(name), score_(score) {}
std::string name_;
float score_;
};
bool operator<(const Person a, const Person b) {
return a.score_ > b.score_;
}
int main() {
std::vector<Person> data {{"zhangsan", 90}, {"lisilisi", 70}, {"wanger", 65}, {"xiaowu", 95}};
std::sort(data.begin(), data.end());
for_each(data.begin(), data.end(), [](Person i){std::cout << i.name_ << ":" << i.score_ << std::endl; });
return 0;
}
仿函数是可调用对象的一种,是指一个具有operator()成员函数的类对象
前面都是举例的排序,下面将set改为忽略大小写,即对字符串的大小写不敏感
struct Cmp {
bool operator()(std::string const&a, std::string const& b) const {
return strcasecmp(a.c_str(), b.c_str()) < 0;
}
};
int main() {
std::set<std::string, Cmp> name_list{"zhoujielun", "linjunjie", "axin", "xiaojingteng"};
for_each(name_list.begin(), name_list.end(), [](std::string i){std::cout << i << std::endl; });
name_list.insert("ZHoujieLun");
name_list.insert("ZHOUJIELUN");
name_list.insert("ZHoujieLUN");
for_each(name_list.begin(), name_list.end(), [](std::string i){std::cout << i << std::endl; });
return 0;
}
可以看到前后两次输出都是一样的。