1009 Product of Polynomials (25 分)

1009 Product of Polynomials (25 分)

水题

  1. 处理有一点小小的麻烦
  2. 用vector很舒服哈哈哈。

代码

#include<cstdio>
#include<iostream>
#include<vector>
#include<algorithm>
// #include
using namespace std;

typedef struct Node{
    int exp;
    double coe;
    Node(){}
    Node(int exp_,double coe_){
        exp=exp_;
        coe=coe_;
    }
    bool operator<(struct Node node){
        return exp>node.exp;
    }
} Node;
vector<vector<Node>>v;
vector<Node>sum_;
double my_abs(double a){
    if(a<0){
        a=-a;
    }return a;
}
int main(){
    int n,m;
    cin>>n;
    vector<Node>tmp;
    int val;
    double coe;
    for(int i=0;i<n;i++){
        scanf("%d%lf",&val,&coe);
        tmp.push_back(Node(val,coe));
    }
    v.push_back(tmp);
    tmp.clear();
    cin>>m;
    for(int i=0;i<m;i++){
        scanf("%d%lf",&val,&coe);
        tmp.push_back(Node(val,coe));
    }
    v.push_back(tmp);
    
    for(int i=0;i<n;i++){
        for(int j=0;j<m;j++){
            val=v[0][i].exp+v[1][j].exp;
            coe=v[0][i].coe*v[1][j].coe;
//             printf("begin: %.3f %.3f %d %.1f\n",v[0][i].coe,v[1][j].coe,val,coe);
            sum_.push_back(Node(val,coe));
        }
    }
    
    sort(sum_.begin(),sum_.end());
    if(sum_.size()<=0){
        return -1;
    }
    
    int i=0;
    vector<Node>res;
    int prev=sum_[0].exp;
    double cum_sum=sum_[0].coe;
    i=1;
    while(i<sum_.size()){
        if(sum_[i].exp!=prev){
            if(my_abs(cum_sum)>0.00000000001){
                res.push_back(Node(prev,cum_sum));
            }
            prev=sum_[i].exp;
            cum_sum=sum_[i].coe;
            i++;
            continue;
        }
        cum_sum+=sum_[i].coe;
        i++;
    }
    res.push_back(Node(prev,cum_sum));
    cout<<res.size();
    if(res.size()>0){
        cout<<" ";
    }
    for(int i=0;i<res.size();i++){
        printf("%d %.1f",res[i].exp,res[i].coe);
        if(i<res.size()-1){
            printf(" ");
        }else{
            printf("\n");
        }
    }
    return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值