对Vector内的结构体对象按照结构体内某成员进行排序

C++结构体排序与成员函数作为比较器
本文介绍了如何在C++中定义一个结构体,并使用成员函数作为比较器进行排序。示例展示了如何创建一个包含浮点数、整数和字符串的结构体,然后定义一个比较函数用于年龄从小到大排序。当比较函数是类的成员函数时,需要添加`static`关键字。示例中还给出了一个填充和排序结构体向量的代码片段。

        首先定义一个结构体:

struct stu
{
    float y;
    int age;
    string name;
};

        然后定义一个比较函数,并返回布尔值。

bool comp(const struct stu & a, const struct stu & b)
{
    return a.age < b.age;
}

        这个是从小到大的排序。

vector<stu> vl;
for (size_t i = 0; i < 15; i++)
{
   left_stu.y = i*1.42;
   left_stu.age = 30-i;
   vl.push_back(left_stu);
}
sort(vl_stu.begin(), vl_stu.end(), comp);

遇到问题:当比较函数作为一个类的成员函数是需要加static

static bool comp1(const struct stu & a, const struct stu& b)
    {

        return a.age< b.age;
    }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值