sort(a,a+n,cmp) 结构体按某一成员变量排序

本文介绍了一个使用C++进行结构体数组排序的例子。通过定义结构体并使用自定义比较函数,实现了按结构体成员变量高度进行升序排列的功能。代码展示了如何读取结构体数组、排序以及输出排序后的结果。
#include<iostream>
#include<cstring>
#include<cmath>
#include<algorithm>
#define ll long long
#define inf 12345
using namespace std;
struct node
{
    int x1,x2,h;
}a[20010];
bool cmp(node xx,node yy)
{
    if(xx.h<=yy.h)
        return true;
    return false;
}
int main()
{
    std::ios::sync_with_stdio(false);
    int n;
    cin>>n;
    for(int i=0;i<n;i++)
    {
        cin>>a[i].x1>>a[i].x2>>a[i].h;
    }
    sort(a,a+n,cmp);
    for(int i=0;i<n;i++)
        cout<<a[i].x1<<" "<<a[i].x2<<" "<<a[i].h<<endl;
    return 0;
}

//输入:
//3
//1 1 1
//3 3 3
//2 2 2
//输出:
//1 1 1
//2 2 2
//3 3 3

 

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值