重载运算符

首先明白一个概念,何谓重载的运算符,并不是按照某些规则的大小,只是你希望它在排序中的先后顺序,按照同一规则,需要倒序排序的重载运算符"<"跟正序排序的重载运算符"<"里面要比较结构体部分数据的大小不同的。
其次,为什么要重载运算符,因为像结构体的的数据结构是没有机器是没有办法对他排序的,所以需要我们自定义其排序规则。
举例:
struct Data{
    char name[101];
    int age;
    int grade;
    bool operator < (const Data data) const{
        if(grade == data.grade){
            int tmp = strcmp(name,data.name);
            if(tmp == 0){
                return age < data.age;
            } else{
                return tmp<0;
            }
        } else{
            return grade > data.grade;
        }

    };
}arr[1001];
这样就能根据我们定义的规则:先比较两者成绩,成绩高的在前面,成绩相同,比较姓名,姓名比较根据字典排序,姓名相同则比较年龄。
因为只是举例,所以并无实际意义。

根据我们重载的运算符,结合sort函数,就可以对我们自定义的结构体进行排序。
点赞