Problem H: 稀疏矩阵的表示和运算 SDUSTOJ

本来想用 vector ,试了下不好实现,换用 node 的数组
重载运算

#include<iostream>
#include<cstdio>
#include<vector>
#include<algorithm>
#include<set>
using namespace std;
const int maxn = 10000;

struct node {
    int r, c, v;
};

bool cmp(node aa, node bb) {
    if(aa.r == bb.r) return aa.c < bb.c;
    return aa.r < bb.r;
}

class Triple
{
private:
    node a_[maxn];
    int len;
public:
    Triple() {}
    ~Triple() {}
    friend istream &operator >> (istream &in, Triple &t) {
        int i = 0;
        while(1) {
            in >> t.a_[i].r >> t.a_[i].c >> t.a_[i].v;
            if(t.a_[i].r == 0 &&  t.a_[i].c == 0) break;
            ++i;
        }
        t.len = i;
        return in;
    }
    friend ostream &operator << (ostream &out, Triple& t) {
        sort(t.a_, t.a_+t.len, cmp);
        //cout << "++++" << endl;
        for(int i = 0; i < t.len; i++)  {
            if(t.a_[i].v != 0)
                out << t.a_[i].r << " " << t.a_[i].c << " " << t.a_[i].v << endl;
        }
        //cout << "++++" << endl;
        return out;
    }
    Triple operator + (Triple &b) {
        for(int i = 0; i < b.len; ++i)
            a_[i+len] = b.a_[i];
        len = len + b.len;
        sort(a_, a_+len, cmp);
        for(int i = 0; i < len-1; ++i)
        if(a_[i].r == a_[i+1].r && a_[i].c == a_[i+1].c) {
            a_[i].v += a_[i+1].v;
            a_[i+1].v = 0;
        }
        return *this;
    }
};

int main()
{
    Triple mat1, mat2, mat3;
    cin>>mat1;
    cin>>mat2;
    mat3 = mat1 + mat2;
    cout<<mat3;
    return 0;
}
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值