结构体sort、结构体优先队列的实现——结构体内嵌比较函数(重载运算符bool operator)

sort:

struct node
{
    int l, r;
    //返回一个bool值(排序涉及是否交换),两个const防止调用的变量发生变化
    bool operator <(const node& a)const {
        return l < a.l;//小于号 代表 从小到大 排序

        //return l != a.l ? l < a.l : r > a.r 也可完成更复杂的排序
        //如果 l 不同就按 l 从小到大排序,否则按 r 从大到小排序
    }
}z[N];

//另一种写法,cmp比较函数
bool cmp(node a, node b) {
    return a.l < b.l;
}

结构体内部设定,重载设定好后就可以直接存入 z 数组然后sort排序

	cin >> n;
    for (int i = 0; i < n; i++)
        cin >> z[i].l >> z[i].r;

    sort(z, z + n);//sort(z, z + n, cmp)

    for (int i = 0; i < n; i++)
        cout << z[i].l << ' ' << z[i].r << endl;

优先队列 priority_queue:

可用自带的函数greater、less来设定小根堆、大根堆,但缺点是只能根据第一个关键字排序

struct Ver
{
    int pre, cur, id;
     //只能根据 pre 来排序
};

int main() {
    
    priority_queue<Ver, vector<Ver>, greater<Ver> > q1;
    //存入堆的类型、存放的容器、排序类型

    priority_queue<Ver, vector<Ver>, less<Ver> > q2;

    return 0;
}

手写重载运算符bool operator

struct Ver
{
    int pre, cur, id;
    bool operator < (const Ver& a)const {
       // return id < a.id;
       //注意堆默认状态下是从大到小排序(大根堆),与sort相反
       //所以这里是反过来:根据 id 从大到小排序

        //可以实现更复杂的排序,不只是根据一个关键字:
        if (id != a.id)return id < a.id;
        else if (cur != a.cur)return cur > a.cur;
        else return pre < a.pre;
    }
};

int main() {
    
    priority_queue<Ver> q;
    //定义也简单

    q.push({ 1,1,1 });
    while (q.size())
    {
        Ver t = q.top();
        pri("%d %d %d\n", t.pre, t.cur, t.id);

        sca("%d %d %d", &t.pre, &t.cur, &t.id);
        q.push(t);
    }

    return 0;
}
重载运算符只是为结构体中的对象定义了自定义的比较规则,它并不能自动对结构体中的对象进行排序。重载小于号(<)运算符只是定义了对象之间的比较方式,并不会自动应用到结构体中的对象排序上。 如果你想在结构体实现自动排序,你可以使用标准库提供的排序算法,例如 `std::sort`。你需要为结构体定义一个比较函数(可以是成员函数或非成员函数),然后将该函数作为参数传递给排序函数。 以下是一个示例,演示如何在结构体中使用重载运算符排序算法实现自动排序: ```cpp #include <iostream> #include <vector> #include <algorithm> struct MyStruct { int value; bool operator<(const MyStruct& other) const { return value < other.value; } }; int main() { std::vector<MyStruct> vec { {5}, {2}, {8}, {1} }; // 使用重载的小于号运算符进行排序 std::sort(vec.begin(), vec.end()); // 输出排序后的结果 for (const auto& obj : vec) { std::cout << obj.value << " "; } std::cout << std::endl; return 0; } ``` 在这个示例中,我们定义了一个结构体 `MyStruct`,其中包含一个整数成员变量 `value`。我们重载了小于号运算符,使用 `value` 成员变量进行比较。 在 `main()` 函数中,我们创建了一个 `std::vector` 容器,并向其中添加了几个 `MyStruct` 对象。然后,我们使用 `std::sort` 算法对容器中的对象进行排序。由于我们重载了小于号运算符,所以排序算法会根据对象的 `value` 成员变量进行比较,并按照升序排序。 因此,重载运算符可以帮助我们定义对象之间的比较规则,但如果想要实现自动排序,我们还需要借助排序算法实现
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值