码迷,mamicode.com
首页 > 编程语言 > 详细

自定义排序

时间:2020-03-28 16:22:46      阅读:79      评论:0      收藏:0      [点我收藏+]

标签:pac   数据   div   for   准备   int   年龄   system   color   

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

 

自定义排序

标签:pac   数据   div   for   准备   int   年龄   system   color   

原文地址:https://www.cnblogs.com/Knightl8/p/12587803.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!