自定义排序

Posted knightl8

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了自定义排序相关的知识,希望对你有一定的参考价值。

#include <iostream>
#include <string>
#include <list>
using namespace std;

//list容器 排序案例 对于自定义数据类型 做排序

//按照年龄进行升序,如果年龄相同按照身高进行降序
class Person
{
    public:
        Person(string name,int age,int height)
        {
            this->m_Name=name;
            this->m_Age=age;
            this->m_Height=height;
        }
        string m_Name;
        int m_Age;
        int m_Height;

};

//指定排序规则
bool comparePerson(Person &p1,Person &p2)
{
    //按照年龄升序
    if(p1.m_Age == p2.m_Age)
    {
        //年龄相同 按照身高排序
        return p1.m_Height > p2.m_Height;
    }
    else
    {
        return p1.m_Age < p2.m_Age;
    }
    
    
}
void test01()
{
    list<Person>L; //准备容器

    //准备数据
    Person p1("刘备", 35 , 175);
    Person p2("曹操", 45 , 180);
    Person p3("孙权", 40 , 170);
    Person p4("赵云", 25 , 190);
    Person p5("张飞", 35 , 160);
    Person p6("关羽", 35 , 200);

    //插入数据
    L.push_back(p1);
    L.push_back(p2);
    L.push_back(p3);
    L.push_back(p4);
    L.push_back(p5);
    L.push_back(p6);

    for(list<Person>::iterator it=L.begin();it!=L.end();it++)
    {
        cout<<"姓名: "<<it->m_Name<<" 年龄: "<<it->m_Age<<" 身高: "<<it->m_Height<<endl;
    }

    //排序
    cout<<"------------------"<<endl;
    cout<<"排序后 "<<endl;

    L.sort(comparePerson);
    for(list<Person>::iterator it=L.begin();it!=L.end();it++)
    {
        cout<<"姓名: "<<it->m_Name<<" 年龄: "<<it->m_Age<<" 身高: "<<it->m_Height<<endl;
    }

}

int main(void)
{
    test01();



    system("pause");

    return 0;
}

 

以上是关于自定义排序的主要内容,如果未能解决你的问题,请参考以下文章

VSCode自定义代码片段(vue主模板)

VSCode自定义代码片段——声明函数

VSCode自定义代码片段——.vue文件的模板

VSCode自定义代码片段——git命令操作一个完整流程

VSCode自定义代码片段8——声明函数

VSCode自定义代码片段1——vue主模板