stl的比较器:自定义数据排序方式,set忽略大小写

stl自定义的比较器主要用于实现容器中元素的比较。比较器的定义的方式主要有下面三种:

1.普通函数

对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;
}

3.仿函数

仿函数是可调用对象的一种,是指一个具有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;
}

可以看到前后两次输出都是一样的。

你可能感兴趣的:(编程,linux)